打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
linux中的dmesg命令简介
userphoto

2015.12.26

关注

        今天, 我们来介绍一个linux中的dmesg命令,事实上, 我们之前用过, 但是没有单独介绍过。 


        看一下dmesg命令的用途吧:

        dmesg命令用会把开机信息存到ring bufer中, 形成一个缓冲, 免得你我来不及看。 在root权限下, 可以用dmesg -c来清楚这个消息。 单纯的一个dmesg命令则是用来输出这些记录信息的。


        要注意, 程序core dump之后, 并不一定产生core文件, 此时, 我们的重要目的是: 获取出错堆栈的地址, 而dmesg命令可达此目的。

        下面, 我们来看一下经典的dmesg + addr2line

  1. [taoge@localhost test]$ cat test.c -n  
  2.      1  #include <stdio.h>  
  3.      2  
  4.      3  int main()  
  5.      4  {  
  6.      5          int *p = NULL;  
  7.      6          *p = 0;  
  8.      7  
  9.      8          printf("bad\n");  
  10.      9          return 0;  
  11.     10  }  
  12. [taoge@localhost test]$ gcc -g test.c   
  13. [taoge@localhost test]$ ./a.out  
  14. Segmentation fault (core dumped)  
  15. [taoge@localhost test]$   
  16. [taoge@localhost test]$   
  17. [taoge@localhost test]$   
  18. [taoge@localhost test]$ dmesg  
  19. a.out[3709]: segfault at 0 ip 080483c9 sp bff75a60 error 6 in a.out[8048000+1000]  
  20. [taoge@localhost test]$ addr2line -e a.out 080483c9  
  21. /home/taoge/test/test.c:6  
  22. [taoge@localhost test]$   

        可见, 第6行有错, addr2line是我们的老熟人了, 本文主要强调一下dmesg.  当dmesg显示的信息较多时候, 我们通过grep来过滤, 比如 dmesg | grep a.out


       在实际开发中, 通常是从日志文件中看到堆栈异常, 同样是为了拿到堆栈出错的地方, 然后用addr2line来定位代码行, 此时, 可以将日志文件看成是dmesg命令的扩展。 在这两种情况下, 我么可以不依赖于core文件, 便可搞定core dump了。   


         OK, dmesg命令的介绍就先告一段落了。




本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
addr2line命令
Linux 常用命令:开发调试篇
strip命令简介
如何在没有core文件的情况下用dmesg+addr2line定位段错误
Linux下mkdir命令如何使用?
linux测试中常用命令查看一些硬件信息
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服