Android-app、system、kernel 抓取logo

                                               日誌抓取

 

 (四類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 shell dmesg                       //kernel 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的狀態

 

1.安裝abd環境 

         1)百度搜索:adb.exe下載附件adb.exe包,

         2)百度再搜索:AdbWinApi.dll下載

     (注:這裏不能傳壓縮包,想要的去羣文件下載,找不到的私密我)    

        3)解壓後放到電腦C盤,C:WINDOWSsystem32

2.手機數據線連着電腦

3. 打開cmd窗口輸入adb devices,出現下面畫面,說明連接成功。沒連接成功的可以打開360安裝手機驅動

4.cmd窗口輸入:adb logcat>d:/1.txt

5.在電腦d盤查看1.txt文件

6.打開txt文本,搜索關鍵字:FATAL找到如下信息,於是就捉到log了

FATAL EXCEPTION: mainE/AndroidRuntime( 2027): java.lang.NullPointerExceptionE/AndroidRuntime( 2027):
  at android.view.ViewConfiguration.get(ViewConfiguration.java:331)E/AndroidRuntime( 2027):
  at android.view.View.(View.java:2730)E/AndroidRuntime( 2027):
  at android.view.ViewGroup.(ViewGroup.java:382)E/AndroidRuntime( 2027):
  at android.widget.LinearLayout.(LinearLayout.java:166)E/AndroidRuntime( 2027):
  at com.elan.ui.OtherArticleLayout.(OtherArticleLayout.java:33)E/AndroidRuntime( 2027):
  at com.elan.fragment.PublishContentFragment$1.handleMessage(PublishContentFragment.java:162)E/AndroidRuntime( 2027):
  at android.os.Handler.dispatchMessage(Handler.java:95)E/AndroidRuntime( 2027):
  at android.os.Looper.loop(Looper.java:154)E/AndroidRuntime( 2027):
  at android.app.ActivityThread.main(ActivityThread.java:4945)E/AndroidRuntime( 2027):
  at java.lang.reflect.Method.invokeNative(Native Method)E/AndroidRuntime( 2027):
  at java.lang.reflect.Method.invoke(Method.java:511)E/AndroidRuntime( 2027):
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)E/AndroidRuntime( 2027):
  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)E/AndroidRuntime( 2027):
  at dalvik.system.NativeStart.main(Native Method)E/EmbeddedLogger( 1573):
 App crashed! Process: com.elan.activityE/EmbeddedLogger( 1573):
 App crashed! Package: com.elan.activity v41 (3.97)E/EmbeddedLogger( 1573):
 Application Label: 一覽W/ActivityManager( 1573):
   Force finishing activity

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章