zoukankan      html  css  js  c++  java
  • 没有core文件时候如何定位segment/core dump

     我们知道, 程序segment fault后, 不一定会产生core文件, 如果有core文件, 那还好, 如果没有core或者是坏core, 那该怎么办呢?

           之前我们说过用add2line的方法来定位, 当时用了addr2line和dmesg命令, 今天我们来介绍类似的方法, 以方便在不同场景下多一个思路, 说不定能救命。

           看程序:

    1. #include <iostream>  
    2. using namespace std;  
    3.   
    4. int main()   
    5. {  
    6.     int *p = NULL;  
    7.     *p = 0;  
    8.   
    9.     return 0;  
    10. }  

          用g++ -g test.cpp来编译, 然后运行./a.out

          我们照样可以用之前的addr2line和dmesg来定位, 试了一下, 可以定位出原因。 下面我们来介绍利用系统log文件和addr2line来定位, 如下:

    1. xxxxxx# ./a.out   
    2. Segmentation fault   (注意: 如果我机器上的core开关打开了, 就会提示Segmentation fault(core dumped), 类似提示大家应该见过, 比如Aborted(core dumped))  
    3. xxxxxx# cat /var/log/messages | grep -i seg  
    4. Apr  2 15:13:19 yyyyyy kernel: a.out[24764]: segfault at 0 ip 000000000804854f sp 00000000ffc9e7d4 error 6 in a.out[8048000+1000]  
    5. xxxxxx# addr2line -e a.out 000000000804854f  
    6. /data/home/zzzzzz/test.cpp:7  
    7. xxxxxx#   

          done, 问题查出来了。

          以后, 在没有core时, 可以优先看:

          1. /var/log/messages

          2. dmesg

          3. /var/log/dmsg

  • 相关阅读:
    VSS部署手册
    正则表达式学习(二)
    完全卸载oracle11g步骤
    c#中 命令copy 已退出,返回值为1
    Windows 64位下装Oracle 11g,PLSQL Developer的配置问题,数据库处显示为空白的解决方案
    ora01033和ora12560错误的解决方案
    C#DLL加密保护
    ocslive.conf
    ASP.NET中文乱码问题的解决
    Creating a very simple autorestore USB stick clonezilla
  • 原文地址:https://www.cnblogs.com/chixinfushui/p/9019270.html
Copyright © 2011-2022 走看看