Android adb命令 抓取系统各种 log

转自:https://www.cnblogs.com/bluestorm/p/9188159.html ,记录一下,以便查阅

getLog.bat:

adb root
adb remount
adb wait-for-device
adb logcat -v time > C:\log.txt

 

在Android中不同的log写到不同的设备中,共有/dev/log/system, /dev/log/main, /dev/log/radion, /dev/log/events四中类型。其中默认Log.v等写入/dev/log/main中。Slog写入/dev/log/system中。

adb logcat -b <system, radio, events, main(default)>

main — 查看主缓冲区 (默认缓冲区)   

radio — 查看包含在无线/电话相关的缓冲区消息   

events — 查看事件相关的消息

 

1.app log adb logcat –v time > c:\appLog.txt

2.radio log adb logcat –v time –b radio >c:\radioLog.txt

3.kernel log adb shell cat /proc/kmsg > kernel.log

4.导出当前缓存的kernel log adb shell dmesg

5.实时查看kernel log adb shell kmsgcat


 

1、logcat

(四类log buffer是main,radio,system,events)

adb wait-for-device logcat

adb logcat -v time > logcat.txt //默认是-b main -b system

adb logcat -v time -b main //main log

adb logcat -v time -b radio //radio log

adb logcat -v time -b system //system log

adb logcat -v time -b events

 

2、anr log

adb pull /data/anr

 

3、tombstone log

adb pull /data/tombstones

 

4、core log

adb pull /data/log/core

 

5、开机log

adb shell dmesg > dmesg.txt

 

6、logcatch

adb pull /data/logcatch

 

7、qxdm log

adb pull /sdcard/logs

 

8、 hprof log

在分析app 时,我们通常需要分析app 的java heap 资料,如分析java 的memory leak, 追查heap 中相关变量情况等。

在android 中抓取app 的hprof 操作方式有下面几种: 第一种方式: 使用am 命令 adb shell am dumpheap {Process} file 如 adb shell am dumpheap com.android.phone /data/anr/phone.hprof adb pull /data/anr/phone.hprof

第二种方式: 使用DDMS 命令 在DDMS 中选择对应的process, 然后在Devices 按钮栏中选择Dump Hprof file, 保存即可

第三种方式: 通过代码的方式 在android.os.Debug 这个class 中有定义相关的抓取hprof 的method. 如: public static void dumpHprofData(String fileName) throws IOException; 这样即可在代码中直接将这个process 的hprof 保存到相对应的文件中,注意这个只能抓取当时的 process.

如果想抓其他的process 的hprof, 那么就必须通过AMS 帮忙了。 可以先获取IActivityManager 接口,然后调用它的dumpheap 方法。具体的代码,大家可以参考 frameworks/base/cmds/am/src/com/android/commands/am/am.java 中的调用代码

抓取回hprof 后,就可以用hprof-conv 命令将DVM 格式的hprof 转换成标准的java 命令的hprof hprof-conv in.hprof out.hprof 然后使用如MAT 之类的工具进行具体的分析

 

9、bugreport

adb bugreport > bugreport.txt

 

10、kernel log(只有从当前时间起的很少的log)

cat proc/kmsg > kmsg.txt

 

11、其他

adb shell dumpstate //各类信息,比如进程信息,内存信息,进程是否异常,kernnel的log等 adb shell dumpcrash adb shell dumpsys //查询所有service的状态

 


ref:

https://blog.csdn.net/matthewei6/article/details/50596983

https://www.cnblogs.com/zhengtu2015/p/5134012.html

 

Android logcat命令详解

https://www.cnblogs.com/JianXu/p/5468839.html

 

解读Android LOG机制的实现 https://www.cnblogs.com/hoys/archive/2011/09/30/2196199.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值