博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ChkBugReport使用指南
阅读量:4220 次
发布时间:2019-05-26

本文共 2340 字,大约阅读时间需要 7 分钟。

ChkBugReport是一个开源工具,它可以把你得到的bugreprot解析成适合阅读的html文件。导出的html文件包含了根据bugreport数据得出的图表和分析结论。

它用到了以下开源类库:

  •  plugin

目前ChkBugReport可以从bugreport数据中抽取出如下信息:

  1. Stacktraces ChkBugReport可以从bugreport中解析出输出bugreport的最后时刻、导致ANR时刻甚至更多时刻的堆栈信息。在 中你可以看到进程的优先级和策略都已标示出来,堆栈中耗时的部分颜色是黑红,一些违反Strict Mode的部分(比如主线程中使用数据库)颜色标记为亮红。如果这个线程死锁,在报告的Errors将会出现。
  2. Logs 这部分是对system、main和kernel日志的分析,在这里你可以看到每个进程内存使用图、那个程序产生的log最多、Activity的启动耗时、数据库操作耗时统计、对象被锁定时间、AIDL调用时间、Activity和Service的生命周期及其在内存中使用频率等等,
  3. Packages ChkBugReport解析bugreport中存储的packages.xml并展示一系列的packages、user ids和 permissions。参加
  4. Processes 操作app过程中产生的系统事件日志、内存使用信息等等,
  5. Battery statistics 电池使用统计信息,
  6. CPU Frequency statistics CPU频率统计信息,
  7. Raw data 被分割成小段的原始数据

等等同时ChkBugReport也可以检测到(潜在的)错误,这些错误在输出的报告Errors中可以找到。你也可以在输出报告的stacktrace中找到死锁或一些违反Strict Mode的行为。

1、分析Bugreport文件

java -jar $HOME/Downloads/chkbugreport.jar $HOME/tmp/bugreport.txt

你也可以把chkbugreport.jar加到path下,然后这样使用,这将根据你的bugreport数据输出一个分析结果目录bugreport_out。

chkbugreport thebugreport.txt

你可以使用如下命令取得bugreport:

adb bugreport > bugreport.txt

2、分析BugReport的部分数据

当然你可以使用ChkBugReport分析bugreport的部分数据比如/data/anr/traces.txt

chkbugreport -sl:the_system_log.txt -sa:traces.txt dummy

这将输出分析结果到dummy_out。

3、分析profile文件

你甚至可以使用ChkBugReport分析traceview生成的数据

chkbugreport -t something.prof

附prof数据生成方法:

  1. 可以使用eclipse插件traceview生成
  2. 也可以按如下步骤
    • 用adb shell ps列出所有进程并找出你想要trace的进程的PID
    • 执行adb shell am profile PID start /data/profile.dat,开始分析
    • 操作你的app
    • 执行adb shell am profile PID stop ,停止分析
    • 导出数据并清除临时文件:adb pull /data/profile.dat adb shell rm /data/profile.dat
    • 使用ChkBugReport进行分析 chkbugreport -t profile.dat

4、分析monkey文件

chkbugreport -t something.profjava -jar chkbugreport-0.4-164.jar output_file_name -mo:monkey.log

chkbugreport的常见参数如下:

参数 说明
-ds:file 分析dumsys输出(类似-pb)
-el:file 分析event日志
-ft:file 分析ftrace dump
-ml:file 分析main日志
-mo:file 分析monkey输出并提取堆栈信息
-pb:file 加载bugreport部分数据(例如dumpsys输出的数据)
-pk:file 加载packages.xml
-ps:file 分析 “processes”部分
-pt:file 分析”processes and threads”部分
-sa:file 分析”vm traces at last anr”部分
-sl:file 分析system日志
-sn:file 分析”vm traces just now”部分
-sd:dir 从指定目录加载部分bugreports
-uh:file 加载usage-history.xml

其他参数(较少使用):

不常用参数 说明
–browser 分析完后启动浏览器查看结果报告
–gui 不指定文件名则启动图形界面(开发中)
–silent 不输出非严重错误信息
–limit 限制要分析文件大小
–no-limit 不限制分析文件大小

  1. 开源工具 介绍
  2. ChkBugReport
  3. ChkBugReport最新jar包
  4. 使用ChkBugReport输出的报告参考例子
    • 进程死锁的简单
    • 两个进程相互调用对方的AIDL导致阻塞的死锁
    • 这个例子结合了上面两 (由于一进程调用AIDL阻塞造成另一线程死锁)

转载地址:http://dvomi.baihongyu.com/

你可能感兴趣的文章
leetcode171.[math] Excel Sheet Column Number
查看>>
Log4j配置
查看>>
java发送https请求
查看>>
java发送https请求证书问题
查看>>
js新消息提醒
查看>>
js窗体消息提醒
查看>>
深入Hibernate映射文件(二)——<hibernate-mapping>的属性
查看>>
详解在Spring中进行集成测试
查看>>
Hibernate 的工具类
查看>>
Struts2中过滤器和拦截器的区别
查看>>
51单片机:led灯闪烁10次后熄灭
查看>>
安卓使用okhttp上传文件,服务端PHP接收
查看>>
51单片机:设计有四位数码管,设计3个按键,k1,k2,k3;k1为模式键,第一次按下,显示初始值,k2,k3有效,k2按一次初值加1,k3按一次初值减1;k1第二次按下停止;k1第三次按下清零;
查看>>
安卓:阿里逆地理编码,可直接拿去用
查看>>
thinkphp源码没问题却各种报错,Namespace declaration statement has to be the very first statement in the script
查看>>
android:dkplayer中ijkplayer延迟长的问题,达到秒开的结果
查看>>
安卓:okhttp请求,获取返回数据
查看>>
安卓:股票筛选及分析系统
查看>>
Effective Java 学习笔记一 Object的方法
查看>>
Qt配置信息设置(QSettings在不同平台下的使用路径)
查看>>