桌面端|Electron 崩溃问题分析(!crash_reporter::DumpWithoutCrashing() [crashpad.cc : 262 +)

坑坑不断,开头先说结果,这个崩溃是 Electron 误报,但最好还是要处理,不然崩溃率没法用了。

起因

开开心心过 2024 年元旦,回来第一天上班发现发的新版本崩溃率飙升,这是一个十分恐怖的事情。

分析

锁定问题

突然出现的问题是一致的,虽然分成3份,是因为 mac / windows 都有出现,且不同的架构下报错堆栈不一致。

分析原因

急忙分析问题,因为这个版本从之前使用的 Electron 20.3.12 升级到稳定的 27.1.3 版本,跨了多个大版本,所以第一怀疑就是升级出问题了(最后证明也是跟升级相关,但不是升级的问题)。

先根据最后报错的堆栈信息,排查到这应该是 Chromium 内核发出来的崩溃:

这种网上确实没解,搜不到一点,我们还是要从堆栈里找原因:

可以看到崩溃堆栈出现在一个资源加载类里,看一下 GPT 怎么说的:

能想到是不是哪个资源加载导致整个页面崩溃了?

重现问题

后面发现在开发环境中,也有人上报该崩溃,但上线前被我们忽略了,而且量也非常大,在上线前没有关注开发测试的崩溃数据,问了一圈也没人出现崩溃场景,所以十分很奇怪,这崩溃看起来这么频繁,为什么没有人有感知?

再细究,发现自己的设备也会上报该崩溃,这就好办了,盯着崩溃产生过程来看:

发现启动后自动生成三个崩溃文件去上报 ...

这实锤了,这崩溃没有任何现象,但就是会产生崩溃文件,而且看起来崩溃率是 100% ...

可重现就好办了,最终发现是渲染层的框架页面上有段可疑报错:

细究下来,找到:

基础图标库加载因未包括域名,而导致在桌面端加载到 gaodingpro://xxx 导致的报错。

解决问题

很简单,找到基建的小伙伴补充了域名规则,不再有这个 Error 后,也不会再启动时产生崩溃信息了。

至此解决。

后续

这个问题由来已久,图标库也从来没有用到,一直也是依赖进来的。前一个版本还不会上报这个崩溃,为什么这个版本突然上报了?

只能是猜测是 chromium 内核升级后,把这类问题的优先级提高了,从 Error 提高到 FATAL,导致被 Electron 崩溃采集捕获到,具体源码改动就难找了。好在虚惊一场 ~

这也带给我们思考:

  1. 在上线前要关注开发、测试环境下的崩溃问题。
  2. 渲染页面的 JS Error 不能放过一点,说不定哪天它就升级了。
  3. Electron 确实真坑,像这种要去 chromium 源码里找答案,而不是 Electron 源码,也不会体现在 Electron 各版本升级说明中。

感谢阅读,如果对你有用请点个赞 ❤️

相关推荐
极客小云4 小时前
【Electron-Vue 企业级安全启动模板:electron-vue-theme-template 使用指南】
vue.js·安全·electron
kyle~6 小时前
Electron桌面容器
前端·javascript·electron
H_老邪1 天前
Vue + Electron 项目快速上手指南
前端·vue.js·electron
floret. 小花1 天前
Vue3 + Electron 知识点总结 · 2026-03-21
前端·面试·electron·学习笔记·vue3
码路飞2 天前
Electron 太胖了?试试 Electrobun,12MB 打包一个 AI 桌面助手
typescript·electron
floret. 小花2 天前
Vue3 知识点总结 · 2026-03-20
前端·面试·electron·学习笔记·vue3
UTF_83 天前
iOS动画浅谈
ios·客户端
梦鱼3 天前
🖥️ 告别 Electron 托盘图标模糊:一套精准的 PNG 生成方案
前端·electron
程序员老刘4 天前
跨平台开发地图:金三银四你准备好了吗? | 2026年3月
flutter·客户端