使用 google_breakpad 分析 Electron 崩溃日志文件
2022/2/14 8:11:51
本文主要是介绍使用 google_breakpad 分析 Electron 崩溃日志文件,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前置信息
本机(MacBook Pro)上 Electron 的路径:/usr/local/lib/node_modules/electron/dist/Electron.app/Contents/MacOS/Electron
本机 Electron 数据文件路径:/Users/bianchengsanmei/Library/Application Support/Electron
本地 dump_sysm 路径:/Users/bianchengsanmei/Library/Developer/Xcode/DerivedData/Breakpad-ebqwamwdejfpicartmwratdgdbnc/Build/Products/Release/dump_syms
minidumps_stackwalk 路径 /Users/bianchengsanmei/Public/CODE/google_breakpad/breakpad/src/processor/minidump_stackwalk
构建 google_breakpad
- 下载
google_breakpad
源码;git clone https://github.com/google/breakpad.git
- 编译 google_breakpad
./configure && make
- 安装构建的库
make install
生成 Electron 崩溃日志
// main.js import { app, crashReporter } from "electron"; import * as path from "path"; crashReporter.start({ uploadToServer: false }); app.setPath("crashDumps", process.cwd() + "/crash");
这样当渲染进程崩溃后,我们可在安装目录下的 crash
文件夹下找到一份 dump 文件,这就是崩溃日志文件。
需要注意,在 electron@7.1.4
中,是没有 crashDumps 路径的,统一存在 temp 路径下。
解析 dump 文件
直接打开查看 dump 文件,为 16 进制数据:
需要把该文件转换为可读、可分析的文件,使用工具为 google_breakpad 中的 minidumps_stackwalk:
$ /Users/bianchengsanmei/Public/CODE/google_breakpad/breakpad/src/processor/minidump_stackwalk ./crash/test.dump > ./crash/test.info
打开查看 test.info:
其中最需要注意的是 Crash reason
,是导致崩溃的原因描述。
学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!
你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!
知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!
这篇关于使用 google_breakpad 分析 Electron 崩溃日志文件的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15SendGrid 的 Go 客户端库怎么实现同时向多个邮箱发送邮件?-icode9专业技术文章分享
- 2024-11-15SendGrid 的 Go 客户端库怎么设置header 和 标签tag 呢?-icode9专业技术文章分享
- 2024-11-12Cargo deny安装指路
- 2024-11-02MongoDB项目实战:从入门到初级应用
- 2024-11-01随时随地一键转录,Google Cloud 新模型 Chirp 2 让语音识别更上一层楼
- 2024-10-25Google Cloud动手实验详解:如何在Cloud Run上开发无服务器应用
- 2024-10-24AI ?先驱齐聚 BAAI 2024,发布大规模语言、多模态、具身、生物计算以及 FlagOpen 2.0 等 AI 模型创新成果。
- 2024-10-20goland工具下,如修改一个项目的标准库SDK的版本-icode9专业技术文章分享
- 2024-10-17Go学习:初学者的简单教程
- 2024-10-17Go学习:新手入门完全指南