Android内核开发:如何统计系统的启动时间

简介:

首先了解2个概念:


(1) Android是基于Linux内核的系统,因此Android的启动过程是分为两个阶段的,第一个阶段就是Linux内核的启动,第二个阶段就是Android框架的启动(包括核心服务和程序)。


(2)Android的log系统是独立于Linux内核的log系统的。Linux内核通过printk打印的log信息,这些log写入到了/dev/kmsg文件中,在Shell终端可以通过dmesg命令查看这些log信息。Android框架则是通过Logger驱动打印log信息,这些log并没有归并到kmesg文件中,而是单独存储的,位于/dev/log目录下,在Shell终端可以通过logcat命令来查看。


下面我们分别从两种log信息中找到如何统计系统启动时间的方法。


1.  通过dmesg信息统计系统启动时间


首先,我们通过dmesg命令抓取Linux内核的log信息(部分系统可能需要先执行 adb root):


$ adb shell dmesg > dmesg.txt


Linux内核启动完成,一般都有如下的标准输出信息:


<6> [ 6.613861] Freeing init memory: 176K


因此,只要我们在dmesg.txt文件中找到“Freeing init memory”这一行即可,从上面的log可以看出,Linux内核启动只用了6.613861s。


那么,如何找到Android系统启动完成的标志呢?


很多Android设备在系统启动完成后,会在内核log中打印如下信息:


<6>[ 29.913726] init: processing action 0x96bb8 (property:sys.boot_completed=1)


因此,找到“boot_completed”这一行也就得到了整个系统的启动时间了,从这一行可以看出,整个系统启动用了29.913726s。


当然,并不是所有的Android设备都会打印出这条log,因此,我们一般用下面介绍的方法来专门统计Android系统的启动时间,


2.  通过logcat统计系统的启动时间


文章开头我们已经介绍过,Android的log系统是独立于Linux内核log系统的,通过在终端输入adb shell 进入Android系统,cd到/dev/log目录,你会发现里面有四个文件,分别是:events,main,radio,system.


Android系统把Log分为了四类,不同的类别记录不同的Log信息:


main - 主要的Log信息,大部分应用级别的Log信息都在这里

events - 系统事件相关的Log信息

radio   - 无线/电话相关的Log信息

system - 低级别的系统调试Log信息


默认通过logcat抓取的是main信息,如果想抓取指定类别的log信息的方法,在logcat命令后加-b参数,例如:


1
2
3
4
$ adb logcat -d -v  time  -b  "main"    >  main.txt
$ adb logcat -d -v  time  -b  "events"  >  events.txt
$ adb logcat -d -v  time  -b  "system"  >   system .txt
$ adb logcat -d -v  time  -b  "radio"   >  radio.txt


关于Android Log系统的分类,你可以访问如下页面详细了解: 《Android Logging System》


那么,如何统计Android系统的启动时间呢?


我们可以重点关注events类别的log信息,通过如下命令:


$ adb logcat -d -b events | grep "boot"


如图所示,这是我在高通的APQ8064开发板上抓取的log信息:


wKioL1V5fk2zyWfUAAHv186gKeI487.jpg


“boot_progress_start”代表着Android屏幕点亮,开始显示启动动画,即15.492s开始闪烁Android字样。


“boot_progress_enable_screen”代表着整个系统启动结束,即用了29.986s,用这个总时间减去Linux Kernel的启动时间即可得到Android OS部分的时间。



本文转自 Jhuster 51CTO博客,原文链接:http://blog.51cto.com/ticktick/1660996,如需转载请自行联系原作者

相关实践学习
使用CLup和iSCSI共享盘快速体验PolarDB for PostgtreSQL
在Clup云管控平台中快速体验创建与管理在iSCSI共享盘上的PolarDB for PostgtreSQL。
AnalyticDB PostgreSQL 企业智能数据中台:一站式管理数据服务资产
企业在数据仓库之上可构建丰富的数据服务用以支持数据应用及业务场景;ADB PG推出全新企业智能数据平台,用以帮助用户一站式的管理企业数据服务资产,包括创建, 管理,探索, 监控等; 助力企业在现有平台之上快速构建起数据服务资产体系
相关文章
|
4天前
|
机器学习/深度学习 Java Shell
[RK3568][Android12.0]--- 系统自带预置第三方APK方法
[RK3568][Android12.0]--- 系统自带预置第三方APK方法
22 0
|
4天前
|
Java Linux API
统计android设备的网络数据使用量
统计android设备的网络数据使用量
14 0
|
1天前
|
Java Android开发
Android开发--Intent-filter属性详解
Android开发--Intent-filter属性详解
|
1天前
|
Linux 编译器 开发工具
Android内核的编译过程
Android内核的编译过程
|
1天前
|
物联网 Java 开发工具
安卓应用开发:打造未来移动生活
【5月更文挑战第10天】 随着科技的飞速发展,智能手机已成为我们日常生活中不可或缺的一部分。作为智能手机市场的两大巨头,安卓和iOS分别占据了一定的市场份额。在这篇文章中,我们将重点关注安卓应用开发,探讨如何利用先进的技术和创新思维,为用户打造更加便捷、智能的移动生活。文章将涵盖安卓应用开发的基本概念、关键技术、以及未来发展趋势等方面的内容。
|
2天前
|
Android开发
Android 如何将定制的Launcher成为系统中唯一的Launcher
Android 如何将定制的Launcher成为系统中唯一的Launcher
12 2
|
3天前
|
Java API 开发工具
java与Android开发入门指南
java与Android开发入门指南
10 0
|
4天前
|
Java Android开发
Android OTG U盘无法显示在系统文件管理的修改
Android OTG U盘无法显示在系统文件管理的修改
6 0
|
4天前
|
安全 Android开发
修改Android系统的签名
修改Android系统的签名
14 0
|
4天前
|
安全 Android开发
Android 系统签名
Android 系统签名
13 0