Android日志[进阶篇]一-使用 Logcat 写入和查看日志
Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈)
Android日志[进阶篇]三-Logcat命令行工具
Android日志[进阶篇]四-获取错误报告
Android日志[进阶篇]五-阅读错误报告

目录

  • 前言
  • 从设备上获取错误报告
  • 从 Android 模拟器上获取错误报告
  • 使用 adb 获取错误报告
  • 检查错误报告 ZIP 文件
  • 从用户那里获取报告
    • 腾讯Bugly
    • 友盟
    • Google Play 管理中心
    • Firebase 崩溃报告

前言

大多数人都习惯断点调试,断点复现,但往往效率低下且面对上线后出现的问题无从下手,本文介绍错误日志的获取,logcat之外的日志,也就是线上运行日志或用户设备的日志。

错误报告包含设备日志、堆栈轨迹和其他诊断信息,可以帮助我们查找和修复应用中的错误。通过以下几种方式可以从设备上获取错误报告:使用设备上的生成错误报告开发人员选项、Android 模拟器菜单或开发机器上的 adb bugreport 命令。

图 1. 开发人员选项

如需生成错误报告,必须在设备上启用开发者选项,以便访问生成错误报告(提交错误报告)选项。

从设备上获取错误报告

图 2. 错误报告已准备就绪

如需直接从设备上获取错误报告,请执行以下操作:

  1. 确保设备已启用开发人员选项。
  2. 开发者选项中,点按提交错误报告
  3. 选择所需的错误报告类型(完整或互动式),然后点按报告

    接着收集并提取相关的错误报告,可以从状态栏中看到这个过程,也可以重新命名报告的最终文件名,稍后,便会收到错误报告已准备就绪的通知(参见图 2)。

  4. 如需分享错误报告,请点按该通知。系统会根据可分享的渠道进行分享,如蓝牙等方式传输到电脑

从 Android 模拟器上获取错误报告

在 Android 模拟器中,使用“Extended controls”窗口中的 File a bug 功能:

  1. 点击模拟器面板中的 More 图标 。
  2. Extended controls 窗口中,选择左侧的 Bug report

    此时系统会打开一个屏幕,可以在其中查看错误报告详细信息,例如屏幕截图、AVD 配置信息和错误报告日志。还可以输入一条包含重现步骤的消息,以便与报告一起保存。

  3. 等待错误报告完成收集,然后点击 Save Report

使用 adb 获取错误报告

如果只连接了一台设备,则可以使用 adb 获取错误报告,如下所示:

$ adb bugreport E:\Reports\MyBugReports

如果没有指定错误报告的路径,系统会将其保存到本地目录。

如果连接了多台设备,则必须使用 -s 选项指定设备。运行以下 adb 命令可获取设备序列号并生成错误报告。

$ adb devices

List of devices attached

emulator-5554      device
8XV7N15C31003476 device
$ adb -s 8XV7N15C31003476 bugreport

检查错误报告 ZIP 文件

默认情况下,ZIP 文件称为 bugreport-BUILD_ID-DATE.zip (bugreport-ANE-AL00-HUAWEIANE-AL00-2021-09-10-17-00-09.zip),它可能会包含多个文件,但最重要的文件是 bugreport-BUILD_ID-DATE.txt (bugreport-ANE-AL00-HUAWEIANE-AL00-2021-09-10-17-00-09.txt)。此文件就是错误报告,它包含系统服务 (dumpsys)、错误日志 (dumpstate) 和系统消息日志 (logcat) 的诊断输出。系统消息包括设备抛出错误时的堆栈轨迹,以及从所有应用中使用 Log 类写入的消息。

ZIP 文件中有一个 version.txt 元数据文件,其中包含 Android 版本号,而且启用 systrace 后,ZIP 文件中还会包含 systrace.txt 文件。Systrace 工具 可以获取并显示应用进程和其他 Android 系统进程的执行时间,从而帮助分析应用的性能。

dumpstate 工具会将文件从设备的文件系统复制到 ZIP 文件的 FS 文件夹下,以便引用它们。例如,设备中的 /dirA/dirB/fileC 文件会在 ZIP 文件中生成 FS/dirA/dirB/fileC 条目。


图 3. 错误报告文件结构

如需了解详情,请参阅Android日志[进阶篇]五-阅读错误报告。

从用户那里获取报告

如上所述,开发者使用应用时,获取错误报告非常有用,但最终用户无法轻松地与您分享这些类型的错误报告。如需从真实用户那里获取包含堆栈轨迹的崩溃报告,应该利用 Google Play 和 Firebase 的崩溃报告功能。国内一般使用腾讯bugly和友盟的sdk完成。

腾讯Bugly

支持android 和ios ,文档入口 ,app 需要集成Bugly的SDK,文档有关于android studio和eclipse的集成说明,同时支持离线sdk和远程仓库的依赖,请更新需要进行选择。集成完成以后留意bugly的应用运行情况,可以查看到崩溃记录以及堆栈信息。

友盟

也支持android 和ios,文档入口-应用性能监控 U-APM,app也需要集成友盟的sdk后进行发布。当然需要的帐号需要各位自行去了解和申请。

Google Play 管理中心

由于各种不方便,这个国内基本没人使用,

可以从 Google Play 管理中心获取报告,以便查看从 Google Play 安装应用的用户那里收集的有关崩溃和应用无响应 (ANR) 错误的数据。可以查看过去六个月的数据。

如需了解详情,请参阅 Play 管理中心帮助中心内的查看崩溃和应用无响应 (ANR) 错误。

Firebase 崩溃报告

Firebase Crashlytics 报告会创建有关应用中出现的错误的详细报告。此报告会基于错误是否具有相似堆栈轨迹将其分门别类,并根据错误对用户所产生影响的严重程度进行分级。除自动发送的报告外,您还可以通过记录自定义事件获知导致应用崩溃的操作。

需<将 Firebase 依赖项添加到 build.gradle 文件,即可开始接收用户发送的崩溃报告。如需了解详情,请参阅 Firebase Crashlytics。

Android日志[进阶篇]四-获取错误报告相关推荐

  1. Android日志[进阶篇]五-阅读错误报告

    Android日志[进阶篇]一-使用 Logcat 写入和查看日志 Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈) Android日志[进阶篇]三-Logcat命令行工具 Androi ...

  2. Android日志[进阶篇]三-Logcat 命令行工具

    Android日志[进阶篇]一-使用 Logcat 写入和查看日志 Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈) Android日志[进阶篇]三-Logcat命令行工具 Androi ...

  3. Android日志[进阶篇]一-使用 Logcat 写入和查看日志

    Android日志[进阶篇]一-使用 Logcat 写入和查看日志 Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈) Android日志[进阶篇]三-Logcat命令行工具 Androi ...

  4. Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈)

    Android日志[进阶篇]一-使用 Logcat 写入和查看日志 Android日志[进阶篇]二-分析堆栈轨迹(调试和外部堆栈) Android日志[进阶篇]三-Logcat命令行工具 Androi ...

  5. 微信小程序开发笔记 进阶篇④——getPhoneNumber 获取用户手机号码(小程序云)

    文章目录 一.前言 二.前端代码wxml 三.前端代码js 四.云函数 五.程序流程 一.前言 微信小程序开发笔记--导读 大部分微信小程序开发者都会有这样的需求:获取小程序用户的手机号码. 但是,因 ...

  6. 微信小程序开发笔记 进阶篇⑤——getPhoneNumber 获取用户手机号码(基础库 2.21.2 之前)

    文章目录 一.前言 二.前端代码wxml 三.前端代码js 四.后端java 五.程序流程 六.参考 一.前言 微信小程序开发笔记--导读 大部分微信小程序开发者都会有这样的需求:获取小程序用户的手机 ...

  7. 微信小程序开发笔记 进阶篇⑥——getPhoneNumber 获取用户手机号码(基础库 2.21.2 之后)

    文章目录 一.前言 二.前端代码wxml 三.前端代码js 四.后端java 五.程序流程 六.参考 一.前言 微信小程序开发笔记--导读 大部分微信小程序开发者都会有这样的需求:获取小程序用户的手机 ...

  8. APC控制Linux关机,NAS进阶 篇四:利用APCPowerchuteNetworkShutdown实现断电自动关闭虚拟机...

    NAS进阶 篇四:利用APCPowerchuteNetworkShutdown实现断电自动关闭虚拟机 2020-02-05 21:50:25 20点赞 118收藏 16评论 在2018年写<NA ...

  9. Android日志[基础篇]Android Log日志输出

    Android日志[基础篇]二 Android Studio修改LogCat日志的颜色 android.util.Log输出日志的常用方法如下: Log.v(String tag, String ms ...

最新文章

  1. 《Microsoft Sql server 2008 Internals》读书笔记--第九章Plan Caching and Recompilation(10)
  2. Java 数字转换成汉字
  3. 微信小程序实现循环列表下拉功能(点击事件)
  4. WPF系列 自定控件
  5. Indian Buffet Process(印度自助餐过程)介绍
  6. Exp-00009错误解決
  7. daily scrum 12.2
  8. 深入解读Linux内存管理系列(4)——Memblock管理机制
  9. 基于大数据的舆情分析系统架构(架构篇)
  10. 手把手教你如何对接支付宝支付接口(奶爸级别)
  11. 用html代码写一个表白语言,HTML写代码表白 – 爱心
  12. 笔记本电脑没有外放声音,但是插上耳机有声音的问题解决方法
  13. 国内最牛的Java面试八股,不接受反驳。
  14. Matlab如何调整背景颜色
  15. chrome 有哪些有用的插件
  16. Redis 的高并发实战:抢购系统 --浅奕
  17. multimedia教学设计计算机英语,高中英语教学设计案例
  18. 小志志和小峰峰的日常(SG函数)
  19. 电话号码组成分析 东海陈光剑
  20. 正则校验手机号是否存在3位以上豹子号或升降连号

热门文章

  1. --c语言运算符_C按位运算符-能力问题和解答
  2. 面试官:AtomicInteger是如何保证线程安全?
  3. Mybatis中SQL注入攻击的3种方式,真是防不胜防!
  4. Java对象都是在堆上分配空间吗?答案竟然是...
  5. 微信公众号天气与聊天机器人小功能
  6. php模板意思,php中的 是什么意思
  7. linux 运行unix elf,在Linux中ELF可执行问题
  8. Win11如何切换应用商店网络 Win11切换应用商店网络的方法
  9. win7旗舰版太卡怎么办
  10. Metricbeat添加ip address信息