离线抓取QXDM log方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了离线抓取QXDM log方法相关的知识,希望对你有一定的参考价值。

参考技术A 1 生成qxdm diag配置文件

打开QXDM,打开CFG File Generator,选择log过滤选择,选择存放路径,点击OK即可

2 push Diag.cfg到/sdcard/diag_logs/

adb shell mkdir /sdcard/diag_logs/

adb push Diag.cfg /sdcard/diag_logs/

3  启动抓取log

adb shell

diag_mdlog &

此时log已经启动抓取,按Ctrl+C可停止

4  导出生成的LOG文件

adb pull /sdcard/diag_logs H:/LOG

.qmdl就是我们想要的log文件

5  将qmdl转isf格式

运行QCAT,File->Open,打开从SD取出的log

File->Save,选择菜单,点击保存

上述操作将qmdl文件转成isf格式

android抓取各种log的方法

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 button栏中选择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的状态




































以上是关于离线抓取QXDM log方法的主要内容,如果未能解决你的问题,请参考以下文章

高通QXDM抓log

数据包回放工具-tomahawk

Permutation UVA - 11525(值域树状数组,树状数组区间第k大(离线),log方,log)

如何使用高通QXDM软件进行测试log

Diagnostic Log and Trace——DLT 离线日志存储

我的代码使用 console.log 离线运行,但不在浏览器中