【用法总结】抓取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

示例:

相关推荐
alexhilton3 小时前
Jetpack Compose内部的不同节点类型
android·kotlin·android jetpack
Frank_HarmonyOS4 小时前
Android中四大组件之一的Activity的启动模式
android
似霰5 小时前
HIDL Hal 开发笔记7----简单 HIDL HAL 实现
android·framework·hal
用户2018792831678 小时前
📚 Android Settings系统:图书馆管理员的故事
android
青莲8438 小时前
Android 事件分发机制 - 事件流向详解
android·前端·面试
火柴就是我9 小时前
学习一些常用的混合模式之BlendMode. dst_atop
android·flutter
火柴就是我9 小时前
学习一些常用的混合模式之BlendMode. dstIn
android·flutter
ganshenml10 小时前
【Android】 开发四角版本全解析:AS、AGP、Gradle 与 JDK 的配套关系
android·java·开发语言
我命由我1234510 小时前
Kotlin 运算符 - == 运算符与 === 运算符
android·java·开发语言·java-ee·kotlin·android studio·android-studio
摘星编程11 小时前
【RAG+LLM实战指南】如何用检索增强生成破解AI幻觉难题?
android·人工智能