【用法总结】抓取main_log、events_log、kernel_log日志的方法

做应用开发大部分时候都基础的logcat日志,其实android系统本身提供的不仅有logcat日志,还有events、kernel日志。

Android 底层有几个"log buffer"(缓冲区):

  • main:普通应用/系统日志(默认)
  • system:系统组件日志
  • events:事件日志(EventLog)
  • radio:通信相关
  • 还有 crash 等(新版本)

logcat 本质是从这些 buffer 里读数据的一个工具。

命令如下:

shell 复制代码
logcat            # 默认从 main + system + crash 等读取
logcat -b main    # 只看 main buffer
logcat -b events  # 只看 events buffer

抓取main.log日志

shell 复制代码
adb logcat -b main -v time > events.txt

示例:

通过main.log日志就能分析日常应用的问题,或者framework层的问题。

抓取events日志的方法:

shell 复制代码
adb logcat -b events -v time > events.txt

示例:

通过events.log 事件日志,能分析页面的启动,各种生命周期,应用进程的启动、kill过程等,平时分析anr、进程无故退出、等锁等问题需要用到events日志的。

抓取kernel日志的方法:

shell 复制代码
# 实时显示内核打印信息并保存到android_kmsg.log文件中
adb shell cat /proc/kmsg |tee android_kmsg.log

示例:

相关推荐
Libraeking11 小时前
视觉篇:Canvas 自定义绘图与高级动画的华丽圆舞曲
android·经验分享·android jetpack
Fushize11 小时前
多模块架构下的依赖治理:如何避免 Gradle 依赖地狱
android·架构·kotlin
Jomurphys12 小时前
Kotlin - 类型别名 typealias
android·kotlin
Haha_bj12 小时前
Flutter ——flutter_screenutil 屏幕适配
android·ios
Haha_bj12 小时前
Flutter ——device_info_plus详解
android·flutter·ios
前端小伙计12 小时前
Android/Flutter 项目统一构建配置最佳实践
android·flutter
Mr_sun.14 小时前
Day09——入退管理-入住-2
android·java·开发语言
ujainu15 小时前
告别杂乱!Flutter + OpenHarmony 鸿蒙记事本的标签与分类管理(三)
android·flutter·openharmony
常利兵16 小时前
Android内存泄漏:成因剖析与高效排查实战指南
android
·云扬·16 小时前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql