如何识别Android init 中的缓慢操作
Android 14 开机时间优化措施汇总-CSDN博客
- Android 14 开机时间优化措施-CSDN博客
- 根据systrace报告优化系统时需要关注的指标和优化策略-CSDN博客
- Android系统上常见的性能优化工具-CSDN博客
- Android上如何使用perfetto分析systrace-CSDN博客
- Android系统设置kernel log level的方法-CSDN博客
- Android14系统应用统一裁剪方案_android 开机 服务 裁剪-CSDN博客
- Android系统上Bootchart的使用_android bootchart-CSDN博客
- Android init.rc如何并行执行任务-CSDN博客
- Android init常用调试工具-CSDN博客
- 如何识别Android init 中的缓慢操作-CSDN博客
- Android init 中的wait_for_property指令-CSDN博客
- Android init.rc各阶段的定义和功能-CSDN博客
- Android init.rc的启动流程-CSDN博客
如何识别Android init 中的缓慢操作
在 Android 系统中,init 进程负责启动系统服务、配置属性和执行系统初始化任务。识别和优化 init 进程中的缓慢操作对于提高系统启动性能和整体响应性至关重要。本文档将详细介绍如何识别 init 中的缓慢操作,提供具体的方法和工具,以及如何解决这些问题。
1. 识别 init 中的缓慢操作
1.1 检查 init.rc 文件
init.rc 文件是 init 进程读取的主要配置文件,它定义了服务、属性、启动脚本等。查看 init.rc 文件中的服务定义可以帮助识别潜在的缓慢操作。
-
文件位置:
/system/etc/init.rc或/system/core/rootdir/init.rc
# 示例 init.rc
service myservice /system/bin/myserviceclass mainuser systemgroup systemoneshot
-
识别:检查
service定义是否有oneshot,start、stop命令的配置等。
1.2 查看 init日志
init 进程的日志记录了服务启动、属性设置等信息。分析这些日志可以帮助识别哪些操作可能导致了系统启动的延迟。
adb logcat | grep init
-
查找:查看日志中是否有长时间运行的任务或错误信息。
08-05 08:00:00.000 200 200 I init : Starting service 'myservice'...
08-05 08:00:05.000 200 200 I init : Service 'myservice' has been started
1.3 使用 init进程的调试工具
可以使用 init 的调试工具来分析性能瓶颈。
adb shell dumpsys init
-
查找:在输出中寻找服务启动的时间戳、属性设置等信息。
ActivityManager: Service myservice (PID 1234) running
2. 监控 init 进程的性能
2.1 使用 strace 工具
strace 工具可以监控 init 进程的系统调用和信号。
adb shell strace -p <init_pid> -tt
-
监控:查看
init进程中的系统调用,识别耗时的操作。
[pid 1234] 08:00:00.000000 execve("/system/bin/myservice", ["myservice"], 0x7f000000) = 0
[pid 1234] 08:00:00.000100 read(0, "data\n", 4096) = 5
2.2 使用 perf 工具
perf 工具用于性能分析,查看 init 进程的 CPU 使用情况。
adb shell perf record -p <init_pid> -a
adb shell perf report
-
分析:查看性能瓶颈,识别消耗 CPU 的函数和操作。
Overhead Command Shared Object Symbol50.00% init /system/bin/init [k] syscall30.00% init /system/bin/init [k] kernel_task
2.3 使用 top命令
top 命令可以动态监控系统的进程资源使用情况。
adb shell top -d 1
-
分析:查看
init进程的 CPU 和内存使用情况。
PID PR CPU% S #THR VSS RSS PCY Name
1234 20 1.5 S 10 100M 50M fg init
3. init 中缓慢操作的常见原因与解决方法
3.1 缓慢的服务启动
原因:
-
服务启动时间过长,可能是因为初始化过程复杂或服务本身性能不佳。
解决方法:
-
优化服务代码:检查服务的初始化代码,减少启动时间。
-
调整
init.rc配置:将服务标记为background以使其在后台启动。
service myservice /system/bin/myserviceclass mainuser systemgroup systembackground
-
分离启动任务:将复杂的启动任务拆分成多个较小的任务。
3.2 长时间的属性设置
原因:
-
属性设置操作可能导致系统等待某些条件。
解决方法:
-
检查属性依赖:确保属性设置不会导致长时间的等待。
-
优化属性设置逻辑:改进属性设置的代码逻辑。
3.3 I/O 操作的延迟
原因:
-
频繁的磁盘读写操作会导致启动时间延迟。
解决方法:
-
减少 I/O 操作:优化磁盘访问代码,减少不必要的读写操作。
-
使用内存文件系统:对于频繁读写的文件,考虑使用
tmpfs文件系统。
tmpfs /data/tmp tmpfs size=64M
4. 高级调试与优化工具
4.1 trace 工具
trace 工具可以提供详细的时间跟踪数据来帮助分析 init 进程的性能。
adb shell trace --start -c -p <init_pid>
# Perform the actions you want to trace
adb shell trace --stop
-
分析:查看
init进程的详细时间数据。
4.2 systrace 工具
systrace 可以提供系统级别的性能分析。
adb shell atrace -b 4096 -t 10 -c -a init
-
分析:查看系统性能瓶颈。
5. 示例配置与优化
以下是一些优化 init.rc 文件的示例配置:
5.1 使用 background启动服务
service slow_service /system/bin/slow_serviceclass mainuser systemgroup systembackground
5.2 设置启动优先级
service high_priority_service /system/bin/high_priority_serviceclass mainuser systemgroup systemoneshot# 服务优先启动on property:ro.hardware=high_prioritystart high_priority_service
通过这些方法,可以识别和优化 init 进程中的缓慢操作,从而提升 Android 系统的启动性能和响应速度。
参考链接
-
Android init 源代码文档
-
Android init.rc 配置文件
-
Android 性能分析工具 strace 使用方法
-
Android perf 工具的详细文档
-
Android top 命令参考
-
Android systrace 工具
相关文章:
如何识别Android init 中的缓慢操作
Android 14 开机时间优化措施汇总-CSDN博客 Android 14 开机时间优化措施-CSDN博客根据systrace报告优化系统时需要关注的指标和优化策略-CSDN博客Android系统上常见的性能优化工具-CSDN博客Android上如何使用perfetto分析systrace-CSDN博客Android系统设置kernel log level的…...
JVM:常用工具总结
文章目录 一、jstat工具 一、jstat工具 Jstat工具是JDK自带的一款监控工具,可以提供各种垃圾回收、类加载、编译信息等不同的数据。使用方法为:jstat -gc进程ID每次统计的时间间隔(毫秒)统计次数。 C代表Capacity容量,…...
二染色,CF 1594D - The Number of Imposters
目录 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 1594D - The Number of Imposters 二、解题报告 1、思路分析 并查集&…...
Go语言并发编程-Channel通信_2
Channel通信 Channel概述 不要通过共享内存的方式进行通信,而是应该通过通信的方式共享内存 这是Go语言最核心的设计模式之一。 在很多主流的编程语言中,多个线程传递数据的方式一般都是共享内存,而Go语言中多Goroutine通信的主要方案是Cha…...
Richteck立锜科技电源管理芯片简介及器件选择指南
一、电源管理简介 电源管理组件的选择和应用本身的电源输入和输出条件是高度关联的。 输入电源是交流或直流?需求的输出电压比输入电压高或是低?负载电流多大?系统是否对噪讯非常敏感?也许系统需要的是恒流而不是稳压 (例如 LED…...
Socket 简介与 Java Socket 编程示例
Socket(套接字)是网络通信中的一个关键概念,它是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象。 一、定义与概念 基本概念:Socket可以被视为网络环境中进程间通信的API(应用程序编程接口)&…...
跟着操作,解决iPhone怎么清理内存难题
在如今智能手机功能日益强大的时代,我们使用手机拍照、录制视频、下载应用、存储文件等操作都会占用手机内存。当内存空间不足时,手机运行会变得缓慢,甚至出现卡顿、闪退等现象。因此,定期清理iPhone内存是非常必要的。那么&#…...
React、Vue的password输入框组件,如何关闭自动填充?
有时候我们的表单使用了一个password组件,这时候每次打开新建,都会自动获取浏览器缓存的密码,但是它的上一个input输入框并不是用户名,这时候我们希望我们的表单,每次点开的时候密码是空的,让用户自动输入&…...
HTML+JS+CSS计算练习
可填 题目数量 数字范围 计算符号 题目做完后会弹窗提示正确率、用时 效果图 源代码在图片后面 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevic…...
设计模式使用场景实现示例及优缺点(行为型模式——责任链模式)
在一个遥远的森林深处,有一个和谐的动物王国。这个王国里的动物们都有各自的职责,大家相互合作,共同维护着森林的和平与繁荣。 一天,森林里来了一只迷路的小兔子,她焦急地四处张望,不知道该怎么办。于是&am…...
CSS-1_0 CSS和文档流
文章目录 CSS和文档流如何证明这个流的存在呢?流和display番外:inline-block 碎碎念 CSS和文档流 首先什么叫流呢? 通常来说,我们最终看到的网页是HTML文档中定义的各个元素挨个输出的结果,这种一个接一个输出的方式…...
小程序图片下载保存方法,图片源文件保存!
引言 现在很多时候我们在观看到小程序中的图片的时候,想保存图片的原文件格式的话,很多小程序是禁止保存的,即使是让保存的话,很多小程序也会限制不让保存原文件,只让保存一些分辨率很低的,非常模糊的图片…...
新书速览|深入理解Hive:从基础到高阶:视频教学版
《深入理解Hive:从基础到高阶:视频教学版》 本书内容 《深入理解Hive:从基础到高阶:视频教学版》采用“理论实战”的形式编写,通过大量的实例,结合作者多年一线开发实战经验,全面地介绍Hive的使用方法。《深入理解Hiv…...
钡铼Profinet、EtherCAT、Modbus、MQTT、Ethernet/IP、OPC UA分布式IO系统BL20X系列耦合器
BL20X系列耦合器是钡铼技术开发的一款用于分布式I/O系统的设备,专为工业环境下的高速数据传输和远程设备控制而设计,支持多种工业以太网协议,包括Profinet、EtherCAT、Modbus、MQTT、Ethernet/IP和OPC UA等。如果您正在考虑部署BL20X系列耦合…...
Git分支合并以及分支部分合并 提交记录合并
Git分支合并,以及分支部分合并,提交记录合并 最近工作中用到git分支合并的场景,记录一下. 分支整体合并,合并所有记录 仅合并分支部分代码...
IDEA关联数据库
《IDEA破解、配置、使用技巧与实战教程》系列文章目录 第一章 IDEA破解与HelloWorld的实战编写 第二章 IDEA的详细设置 第三章 IDEA的工程与模块管理 第四章 IDEA的常见代码模板的使用 第五章 IDEA中常用的快捷键 第六章 IDEA的断点调试(Debug) 第七章 …...
【Leetcode】14. 最长公共前缀
leetcode原地址:https://leetcode.cn/problems/longest-common-prefix 描述 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 “”。 示例 1: 输入:strs [“flower”,“flow”,“flight”…...
【BUG】已解决:zipfile.BadZipFile: File is not a zip file
已解决:zipfile.BadZipFile: File is not a zip file 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页,我是博主英杰,211科班出身,就职于医疗科技公司,热衷分享知识,武汉城市开发…...
小白新手搭建个人网盘
小白新手搭建个人网盘 序云服务器ECS重置密码远程连接ECS实例 安装OwnCloud安装Apache服务PHP运行环境NAS挂载挂载验证操作体验 序 阿里云文件存储NAS(Apsara File Storage NAS)是一个可大规模共享访问,弹性扩展的分布式文件系统。本文主要是…...
NineData全面支持PostgreSQL可视化表结构设计
“PostgreSQL 是最像 Oracle 的开源关系型数据库“,也正因为如此,很多企业都青睐 PostgreSQL,拿它当成 Oracle 的替代品。所以毫无疑问,目前 PostgreSQL 在企业中非常常见。 对于直接接触 PostgreSQL 的开发人员而言,…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
vue3 字体颜色设置的多种方式
在Vue 3中设置字体颜色可以通过多种方式实现,这取决于你是想在组件内部直接设置,还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法: 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...
SpringTask-03.入门案例
一.入门案例 启动类: package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统
目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索(基于物理空间 广播范围)2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...
人工智能(大型语言模型 LLMs)对不同学科的影响以及由此产生的新学习方式
今天是关于AI如何在教学中增强学生的学习体验,我把重要信息标红了。人文学科的价值被低估了 ⬇️ 转型与必要性 人工智能正在深刻地改变教育,这并非炒作,而是已经发生的巨大变革。教育机构和教育者不能忽视它,试图简单地禁止学生使…...
招商蛇口 | 执笔CID,启幕低密生活新境
作为中国城市生长的力量,招商蛇口以“美好生活承载者”为使命,深耕全球111座城市,以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子,招商蛇口始终与城市发展同频共振,以建筑诠释对土地与生活的…...
Elastic 获得 AWS 教育 ISV 合作伙伴资质,进一步增强教育解决方案产品组合
作者:来自 Elastic Udayasimha Theepireddy (Uday), Brian Bergholm, Marianna Jonsdottir 通过搜索 AI 和云创新推动教育领域的数字化转型。 我们非常高兴地宣布,Elastic 已获得 AWS 教育 ISV 合作伙伴资质。这一重要认证表明,Elastic 作为 …...
土建施工员考试:建筑施工技术重点知识有哪些?
《管理实务》是土建施工员考试中侧重实操应用与管理能力的科目,核心考查施工组织、质量安全、进度成本等现场管理要点。以下是结合考试大纲与高频考点整理的重点内容,附学习方向和应试技巧: 一、施工组织与进度管理 核心目标: 规…...
解决MybatisPlus使用Druid1.2.11连接池查询PG数据库报Merge sql error的一种办法
目录 前言 一、问题重现 1、环境说明 2、重现步骤 3、错误信息 二、关于LATERAL 1、Lateral作用场景 2、在四至场景中使用 三、问题解决之道 1、源码追踪 2、关闭sql合并 3、改写处理SQL 四、总结 前言 在博客:【写在创作纪念日】基于SpringBoot和PostG…...
