标签:mozilla windbg 函数 sentry modules 崩溃 加载
项目线上出现了闪退问题,查看日志发现是 sentry 模块出问题了
因为用户电脑上没有 pdb 文件,所以无法加载具体函数的调用位置,只能手动去计算
具体步骤是:在 windbg.exe 中加载 sentry.dll 和 sentry.pdb 文件后
使用 lm 命令行拿到 sentry 模块的基地址
lm vm sentry
有了基地址,就可以依靠偏移地址算出函数崩溃时的上下文
比如图上的 sentry_capture_event,
04cd0000 + 2363
上面是 16 进制,还要加上偏移量,也就是 10 进制 115
80,552,803 + 115
最后得出:4CD 2363
使用 u 命令跳到相应的上下文即可
可以看出内部堆栈并没有给出太多有用的信息,所以我们只能通过崩溃时调用的函数来寻找问题
在经过一段时间的寻找,确认崩溃是发生在 sentry_get_modules_list 的内部,这也符合崩溃时日志给出的信息
在调用 load_modules 时崩溃了,进入函数内部进一步排查后发现是 LoadLibraryExW 加载文件时发生了崩溃
暂时的解决方法是先将 load_modules 注释掉
网上有类似的 bug 提交:
- https://hg.mozilla.org/releases/mozilla-beta/rev/f2bdc4baf977
- https://bugzilla.mozilla.org/show_bug.cgi?id=1607574
标签:mozilla,windbg,函数,sentry,modules,崩溃,加载 来源: https://www.cnblogs.com/strive-sun/p/16459682.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。