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

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

起因

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

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

分析

锁定问题

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

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

分析原因

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

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

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

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

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

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

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

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

重现问题

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

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

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

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

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

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

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

细究下来,找到:

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

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

解决问题

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

至此解决。

后续

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

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

这也带给我们思考:

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

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

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

原文链接:https://juejin.cn/post/7321779224339562523 作者:园宵

(0)
上一篇 2024年1月10日 下午5:09
下一篇 2024年1月11日 上午10:00

相关推荐

发表回复

登录后才能评论