欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android的日志系统分层与logcat使用

程序员文章站 2023-12-09 22:08:27
android的日志系统有典型的android层次结构。本文指出路径,分析层次但不分析代码,这里还介绍logcat的使用和log_bg服务。 日志系统分层 1.先从...

android的日志系统有典型的android层次结构。本文指出路径,分析层次但不分析代码,这里还介绍logcat的使用和log_bg服务。

日志系统分层

1.先从驱动开始

  • linux-3.10/drivers/staging/android/logger.c
  • linux-3.10/drivers/staging/android/logger.h
  • logger_init创建4个日志设备文件/dev/main、/dev/events、/dev/radio、/dev/system。
  • 分析代码的话跟踪结构体static const struct file_operations logger_fops实例化的函数进行分析。

2.c/c++本地库和android实时运行库层

在android/system/core/liblog目录下,分析android.mk可知主要是logd_write.c和fake_log_device.c其它根据with_mingw配置。

3.jni

frameworks/base/core/jni/android_util_log.cpp

4.application frameworks

frameworks/base/core/java/android/util/log.java

5.app中使用日志系统

import android.util.slog
然后slog.e(tag,"***")使用错误日志

现在分层

Android的日志系统分层与logcat使用

logcat工具使用

代码路径android/system/core/logcat/logcat.cpp,输入logcat --h查看帮助。

这里我们修改logcat.cpp设置日志系统默认每个日志文件的大小,日志文件的个数

static int g_logrotatesizekbytes = 4096; // 0 means "no log rotation"
static int g_maxrotatedlogs = 10; // 0 means "unbounded"

每个日志文件最大4m,最多10个。当10个日志写满有最新的日志时,原日志名尾号9删除,其余尾号+1,最新日志写到尾号0的日志。实现固定大小,循环使用。

log_bg.sh工具

android/device/softwinner/common/tools/log_bg.sh

前面几个循环是计数,删除,重命名。

系统日志logcat -v time -f /cache/local/boot_log/aw_${count}_system_boot.log &

内核日志cat /proc/kmsg >> /cache/local/boot_log/aw_${count}_kernel_`date +%y%m%d-%h%m`.log &

android开机就会记录日志记录,输入ps查询到

root      1668  1646  1632   948   c0122258 b6f57720 s logcat

在init.rc文件中查找发现日志服务的启动位置android/device/softwinner/common/init.debug.rc

service log_bg /system/bin/sh /system/bin/log_bg.sh
class core
user root
group root system
oneshot

logger.sh工具

android/device/softwinner/common/tools/logger.sh

实际这个工具根据输入参数kernelandroidradioerror调用logcat

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接