core文件怎么分析_c++ crash 分析工具:breakpad

做为一位c++开发人员,如果你没有遇到过线上程序崩溃,说明你写的代码少或者说你的测试同学很给力,或者是你的服务太简单了,这个题外话哈。俗话说,“夜路走多了总会遇到鬼(bug)”。

通常情况下我们生产环境的服务崩溃,如果你比较幸运的话你的程序会生成一个coredump文件(这个文件的路径可以通过/proc/sys/kernel/core_pattern配置)。但是先别高兴太早,这个core文件未必是完整的。因为core文件也有大小限制(简单的配置方法是通过ulimit -c进行配置)。

如果生成的core文件不完整,那么这个core文件相当于废物,因为他没有进程崩溃时完整的内存快照,没法进行调用堆栈分析,即使是完成的core文件那么你的程序也需要带-g进行编译吧否则你看到的是一堆??????,没有函数等符号信息。

如果连core都没有生成那怎么办呢?

可以通过查看Linux内存的日志:dmesg 然后借助addr2line 查看崩溃的函数,如果你的程序是带有-g编译的那你有可能会看到对应的崩溃的函数。

如果以上两种都没有,那怎么办呢?那你就只能gdb attach到进程,然后盯着它等它再次出现了,出现崩溃之后要快速bt查看调用栈,否则时间久了内存也会被回收掉。

为了避免出现以上低效的问题定位,这里给大家介绍一个非常实用的工具库:breakpad 是google顶级公司开源的项目,他的优势在于:

1)接入简单,短短几行代码就可以了

2)符号信息与生产环境上的程序分离

3)生成的崩溃文件极小࿰

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值