Android APP测试的日志文件抓取

简介: 1    log文件分类简介   实时打印的主要有:logcat main,logcat radio,logcat events,tcpdump,还有高通平台的还会有QXDM日志   状态信息的有:adb shell cat /proc/kmsg ,adb shell dmesg,ad...

     1    log文件分类简介

  实时打印的主要有:logcat main,logcat radio,logcat events,tcpdump,还有高通平台的还会有QXDM日志

  状态信息的有:adb shell cat /proc/kmsg ,adb shell dmesg,adb shell dumpstate,adb shell dumpsys,adb bugreport,工程       模式等

  2    LOG抓取详解

  l  实时打印

 

adb logcat -b main -v time>app.log  打印应用程序的log
adb logcat -b radio -v time> radio.log 打印射频相关的log,SIM STK也会在里面,modem相关的ATcommand等,当然跟QXDM差的很远了。
adb logcat -b events -v time  打印系统事件的日志,比如触屏事件。。。
//android log的抓取
adb logcat
//kernel log的抓取
adb shell cat /proc/kmsg
//log 信息的保存
mkdir  /data/anr
logcat *:V > /data/anr/android
demsg >/data/anr/kernel
//按ctrl+c结束log输出
adb pull /data/anr ./log/

  tcpdump 是很有用的,对于TCP/IP协议相关的都可以使用这个来抓,adb shell tcpdump -s 10000 -w /sdcard/capture.pcap,比如抓mms下载的时候的UA profile,browser上网的时候,使用proxy的APN下载,streaming的相关内容包括UA profile等。

  最后是高通平台的QXDM,不管是不是Android,只要使用高通芯片,都会对它很熟悉,当然了,不是高通的芯片就不用提它了。这个不多讲,内容丰富,射频,电话,上网,...凡是高通提供的解决方案,这个都可以抓。(QXDM 的LOG抓取方法请参考QPST、QXDM的基本使用说明及作用)

  l  状态信息

  o   bugreport(命令adb bugreport>bugreport.log)。里面包含有dmesg,dumpstate和dumpsys。

  o   dumpstate是系统状态信息,里面比较全,包括手机当前的内存信息、cpu信息、logcat缓存,kernel缓存等等。

  o    adb shell dumpsys这个是关于系统service的内容都在这个里面,这个命令还有更详尽的用法,比如adb shell dumpsys meminfo system是查看system这个process的内存信息。

  o   kmsg抓取

  adb shell cat /proc/kmsg > kmsg.txt,打开后查msm_kgsl字段

  说明:用于检索用printk生成的内核消息。任何时刻只能有一个具有超级用户权限的进程可以读取这个文件。也可以用系统调用syslog检索这些消息。通常使用工具dmesg或守护进程klogd检索这些消息。proc是一个内存文件系统, 每次读文件kmsg实际是内核内部的循环缓冲区,每读过后,循环缓冲区的东西就被认为已经处理过了(也就是变成无效内容),所以你再次读为空是很正常的 为什么会这样处理呢,循环缓冲区大小有限,内核又随时可能往里面写东西,所以这样处理很正常. 你去查一下/proc/kmsg的信息有没有跟系统日志关联,如果有的话,你就可以读日志文件

  o   dmsg抓取

  adb shell dmesg > dmesg.txt

  说明:dmesg用来显示开机信息,kernel会将开机信息存储在ring buffer中。您若是开机时来不及查看信息,可利用dmesg来查看。dmesg是kernel的log,凡是跟kernel相关的,比如driver出了问题(相机,蓝牙,usb,启动,等等)开机信息亦保存在/var/log目录中,名称为dmesg的文件里。more /var/log/dmesg

  o   工程模式下log的抓取

  对于Apollo手机请拨打*#*#8888#*#* ,然后勾选相应的LOG。待测试结束后,通过SD卡导出LOG到PC.

3.Log分析:

Get Log from Android System
adb bugreport > bugreport.txt
copy bugreport to the current directory.

bugreport里面包含了各种log信息,大部分log也可以通过直接运行相关的程序来直接获得.

  步骤如下:

  1.adb shell 2.进入相关工具程式的目录 3.执行相关程式 4.得到相关信息

  下面以输出进程信息为例 1.adb shell 2.输入ps -P 3.可以看到相关进程信息

  Log Archive Analysis

  1.bugreport

  bugreport记录android启动过程的log,以及启动后的系统状态,包括进程列表,内存信息,VM信息等等到.

  单独察看某个数据可使用cat指令察看,例如cat /proc/meminfo

  2.bugreport结构分析

  (1)dumpstate

  MEMORY INFO

  获取该log:读取文件/proc/meminfo

  系统内存使用状态

  CPU INFO

  获取该log:执行/system/bin/top -n 1 -d 1 -m 30 -t

  系统CPU使用状态

  PROCRANK

  获取该log:执行/system/bin/procrank

  执行/system/xbin/procrank后输出的结果,查看一些内存使用状态

  VIRTUAL MEMORY STATS

  获取该log:读取文件/proc/vmstat

  虚拟内存分配情况

  vmalloc申请的内存则位于vmalloc_start~vmalloc_end之间,与物理地址没有简单的转换关系,虽然在逻辑上它们也是连续的,但是在物理上它们不要求连续。

  VMALLOC INFO

  获取该log:读取文件/proc/vmallocinfo

  虚拟内存分配情况

  SLAB INFO

  获取该log:读取文件/proc/slabinfo

  SLAB是一种内存分配器.这里输出该分配器的一些信息

  ZONEINFO

  获取该log:读取文件/proc/zoneinfo

  zone info

  SYSTEM LOG(需要着重分析)

  获取该log:执行/system/bin/logcat -v time -d *:v

  会输出在程序中输出的Log,用于分析系统的当前状态

  VM TRACES

  获取该log:读取文件/data/anr/traces.txt

  因为每个程序都是在各自的VM中运行的,这个Log是现实各自VM的一些traces

  EVENT LOG TAGS

  获取该log:读取文件/etc/event-log-tags

  EVENT LOG

  获取该log:执行/system/bin/logcat -b events -v time -d *:v

  输出一些Event的log

  RADIO LOG

  获取该log:执行/system/bin/logcat -b radio -v time -d *:v

  显示一些无线设备的链接状态,如GSM,PHONE,STK(Satellite Tool Kit)…

  NETWORK STATE

  获取该log:执行/system/bin/netcfg (得到网络链接状态)

  获取该log:读取文件/proc/net/route (得到路由状态)

  显示网络链接和路由

  SYSTEM PROPERTIES

  获取该log:参考代码实现

  显示一些系统属性,如Version,Services,network…

  KERNEL LOG

  获取该log:执行/system/bin/dmesg

  显示Android内核输出的Log

  KERNEL WAKELOCKS

  获取该log:读取文件/proc/wakelocks

  内核对一些程式和服务唤醒和休眠的一些记录

 

KERNEL CPUFREQ
(Linux kernel CPUfreq subsystem) Clock scaling allows you to change the clock speed of the CPUs on the fly.
This is a nice method to save battery power, because the lower the clock speed is, the less power the CPU consumes.
PROCESSES

  

  获取该log:执行ps -P 

  显示当前进程

  PROCESSES AND THREADS

  获取该log:执行ps -t -p -P

  显示当前进程和线程

  LIBRANK

  获取该log:执行/system/xbin/librank

  剔除不必要的library

  BINDER FAILED TRANSACTION LOG

  获取该log:读取文件/proc/binder/failed_transaction_log

  BINDER TRANSACTION LOG

  获取该log:读取文件/proc/binder/transaction_log

  BINDER TRANSACTIONS

  获取该log:读取文件/proc/binder/transactions

  BINDER STATS

  获取该log:读取文件/proc/binder/stats

  BINDER PROCESS STATE

  获取该log:读取文件/proc/binder/proc/*

  bind相关的一些状态

  FILESYSTEMS

  获取该log:执行/system/bin/df

  主要文件的一些容量使用状态(cache,sqlite,dev…)

  PACKAGE SETTINGS

  获取该log:读取文件/data/system/packages.xml

  系统中package的一些状态(访问权限,路径…),类似Windows里面的一些lnk文件吧.

  PACKAGE UID ERRORS

  获取该log:读取文件/data/system/uiderrors.txt


img_42a4adae4716d0e15c3eeaabfd040044.png

注:转载需注明出处及作者。

流柯      

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
目录
相关文章
|
8月前
|
存储 监控 算法
防止员工泄密软件中文件访问日志管理的 Go 语言 B + 树算法
B+树凭借高效范围查询与稳定插入删除性能,为防止员工泄密软件提供高响应、可追溯的日志管理方案,显著提升海量文件操作日志的存储与检索效率。
240 2
|
数据采集 Web App开发 JavaScript
基于Selenium的Python爬虫抓取动态App图片
基于Selenium的Python爬虫抓取动态App图片
964 68
|
存储 数据可视化 开发工具
【Application Insights】Application Insights存储的Function App的日志存在"Operation Link" 为空的情况
在将 Azure Functions 升级到 .NET 8 和 Isolated Worker 模式后,Application Insights 的请求日志中 `operation_Link` 字段为空,导致分布式追踪无法正常关联。解决方法包括:确保引用正确的 SDK 包(如 `Microsoft.Azure.Functions.Worker.ApplicationInsights`),正确配置 Application Insights 服务,移除默认日志过滤规则,并使用最新依赖包以支持分布式追踪。通过这些步骤,可恢复端到端事务视图的可视化效果。
246 11
|
存储 监控 API
【Azure App Service】分享使用Python Code获取App Service的服务器日志记录管理配置信息
本文介绍了如何通过Python代码获取App Service中“Web服务器日志记录”的配置状态。借助`azure-mgmt-web` SDK,可通过初始化`WebSiteManagementClient`对象、调用`get_configuration`方法来查看`http_logging_enabled`的值,从而判断日志记录是否启用及存储方式(关闭、存储或文件系统)。示例代码详细展示了实现步骤,并附有执行结果与官方文档参考链接,帮助开发者快速定位和解决问题。
365 22
|
运维 应用服务中间件 nginx
docker运维查看指定应用log文件位置和名称
通过本文的方法,您可以更高效地管理和查看Docker容器中的日志文件,确保应用运行状态可控和可监测。
2600 28
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
10230 2
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
478 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
SQL 数据库
【YashanDB知识库】应用绑定参数的慢查询,慢日志抓取不到
【YashanDB知识库】应用绑定参数的慢查询,慢日志抓取不到
|
存储 SQL 关系型数据库
【赵渝强老师】PostgreSQL的运行日志文件
PostgreSQL的物理存储结构包括数据文件、日志文件等。运行日志默认未开启,需配置`postgresql.conf`文件中的相关参数如`log_destination`、`log_directory`等,以记录数据库状态、错误信息等。示例配置中启用了CSV格式日志,便于管理和分析。通过创建表操作,可查看生成的日志文件,了解具体日志内容。
560 3
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL的全量日志文件
MySQL全量日志记录所有操作的SQL语句,默认禁用。启用后,可通过`show variables like %general_log%检查状态,使用`set global general_log=ON`临时开启,执行查询并查看日志文件以追踪SQL执行详情。
332 4