• android adb命令 抓取系统各种 log


    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: adioLog.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

  • 相关阅读:
    Shell printf 命令
    Shell echo命令
    Shell 基本运算符
    Shell 数组
    Shell 传递参数
    Shell 变量
    Spark基础知识汇总
    DataScientist————汇总篇
    Java的Unsafe类
    java 中文字符和unicode编码值相互转化
  • 原文地址:https://www.cnblogs.com/bluestorm/p/9188159.html
Copyright © 2020-2023  润新知