linux crash内核故障分析工具

kdump一般与crash工具联合使用,以便在故障发生的时候,进行问题追踪

配置kdump:

yum install kexec-tools

修改grub:

GRUB_CMDLINE_LINUX 中添加crashkernel=auto

#vim /etc/default/grub 

GRUB_CMDLINE_LINUX="crashkernel=auto console=ttyS0 console=tty0 panic=5 net.ifnames=0 biosdevname=0"

#grub2-mkconfig -o /boot/grub2/grub.cfg

配置:

vim /etc/kdump.conf

path /var/crash            #指定coredump文件放在/var/crash文件夹中

启动服务:

systemctl start kdump.service    
systemctl enable kdump.service    

重启主机

可进行手动触发验证:

#echo 1 > /proc/sys/kernel/sysrq
#echo c > /proc/sysrq-trigger

crash工具安装:

yum install crash  

查看系统内核版本:

# uname -r

3.10.0-1062.9.1.el7.x86_64

下载对应的rpm包,进行安装:

下载地址http://debuginfo.centos.org/7/x86_64/

下载如下两个内核版本对应的包:

kernel-debuginfo-common-x86_64

kernel-debuginfo-

例如:

kernel-debuginfo-common-x86_64-3.10.0-327.el7.x86_64.rpm
kernel-debuginfo-3.10.0-327.el7.x86_64.rpm
# 安装
rpm -ivh kernel-debuginfo-common-x86_64-3.10.0-327.el7.x86_64.rpm
rpm -ivh kernel-debuginfo-3.10.0-327.el7.x86_64.rpm

# cd /var/crash

# ls -lrt

total 510856
drwxr-xr-x 2 root root      4096 Apr 14 12:46 127.0.0.1-2020-04-14-12:46:27

# cd 127.0.0.1-2020-04-14-12:46:27
# ls -l

total 170948
-rw------- 1 root root 174699120 Apr 14 12:46 vmcore
-rw-r--r-- 1 root root    341386 Apr 14 12:46 vmcore-dmesg.txt

查看
# more vmcore-dmesg.txt

[    0.000000] Initializing cgroup subsys cpuset
[    0.000000] Initializing cgroup subsys cpu
[    0.000000] Initializing cgroup subsys cpuacct
[    0.000000] Linux version 3.10.0-1062.9.1.el7.x86_64 (mockbuild@kbuilder.bsys.centos.org) 

分析vmcore

# crash /usr/lib/debug/lib/modules/3.10.0-1062.9.1.el7.x86_64/vmlinux vmcore

crash 7.2.3-10.el7
Copyright (C) 2002-2017  Red H
  • 0
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
kdump是一个在Linux内核崩溃时收集dump信息的工具。它的设计目标是在遇到内核崩溃时,能够提供完整的内核转储信息,以便开发人员进行分析和调试。 kdump的工作原理是在系统启动时,设置一个保护内存区域,用于在内核崩溃时存储dump信息。当系统出现崩溃时,kdump会触发一个内核崩溃的路径,将所有的内核状态信息存储在这个保护区域中。然后,kdump会加载一个独立的小内核,这个小内核只包含了最小的功能,仅仅用于将之前存储的内核状态信息写入磁盘。这样,即使主内核发生崩溃,kdump仍然能够将dump信息保存下来。 kdump所收集的dump信息包含了内核的堆栈、寄存器的状态、内核模块列表、内核代码和数据段等。这些信息对于开发人员分析和调试内核问题非常有帮助。无论是内核中的软件错误、硬件故障还是系统配置错误,都能够通过kdump的信息来定位和解决问题。 为了使用kdump,我们首先需要安装kexec工具,然后对系统进行一些配置,如设置内存保护区域的大小、crashkernel参数等。配置完成后,重新启动系统,当系统崩溃时,kdump就会自动工作。 总结来说,kdump是一个非常有用的Linux内核调试工具,能够在内核崩溃时提供完整的dump信息,为开发人员提供了方便的分析和调试手段。它能够帮助我们快速定位和解决各种内核问题,提高系统的稳定性和可靠性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值