pycod
很多人在说我们讲故事吹NB 但是我们吹过的NB ,正在一一变为现实 !!!!!

CentOS7配置kdump

 

 

1.kdump简介

  • kexec是一个快速启动机制,允许通过已经运行的内核的上下文启动一个Linux内核,不需要经过BIOS。BIOS可能会消耗很多时间,特别是带有众多数量的外设的大型服务器。这种办法可以为经常启动机器的开发者节省很多时间。

  • kdump是一个新的,而且非常可信赖的内核崩溃转储机制。崩溃转储数据可以从一个新启动的内核的上下文中获取,而不是从已经崩溃的内核的上下文。当系统崩溃时,kdump使用kexec启动到第二个内核。第二个内核通常叫做捕获内核(capture kernel),以很小内存启动,并且捕获转储镜像。

  • 第一个内核保留了内存的一部分,第二个内核可以用来启动。注意,在启动时,kdump保留了一定数量的重要的内存,这改变了红帽企业Linux 5最小内存需求。为了计算系统需要的真正最小内存,可以参看 http://www.RedHat.com/rhel/details/limits/ 上列出的最小内存需求,加上kdump使用的内存数量,以决定真正的最小内存的需求。

  • 因为第一个内核的内存内容已经被保留,所以kexec可以不经过BIOS,启动捕获内核。这是内核崩溃转储的根本。

2.配置kdump

  • (1)安装kexec-tools:使用kdump服务,必须要用到kexec-tools工具包。
sudo yum update
sudo yum install kexec-tools

  安装完成之后可以通过kexec -version查看kexec的版本。
  • 1
  • 2
  • 3
  • 4
  • (2)配置kdump kernel,也可以不配置
1.修改grub文件
vim /etc/default/grub
需要将GRUB_CMDLINE_LINUX="crashkernel=auto..."中的auto修改为128M。一般设为128M或256M。

2.更新grub配置
 只要更改了grub文件,都需要更改grub配置。
 sudo grub2-mkconfig -o /boot/grub2/grub.cfg

 3.重启系统
reboot
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • (3)修改kdump默认配置,也可以不配置
vim /etc/kdump.conf

其中,需要注意的三行内容是
path /var/crash            #指定coredump文件放在/var/crash文件夹中
core_collector makedumpfile -c -l -message-level 1 -d 31   #加上-c表示压缩,原文件中没有
default reboot         #生成coredump后,重启系统
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • (4)开启kdump服务
systemctl start kdump.service     //启动kdump
systemctl enable kdump.service    //设置开机启动

检查kdump开启成功
service kdump status
  • 1
  • 2
  • 3
  • 4
  • 5

如下所示,表示开启成功
在这里插入图片描述

  • (5)手动触发crash
#echo 1 > /proc/sys/kernel/sysrq
#echo c > /proc/sysrq-trigger
  • 1
  • 2

如果配置成功,系统将自动重启,重新进入系统,可以看到/var/crash文件夹下生成了相应文件,是一个以生成coredump日期为文件名的文件,如图所示:
在这里插入图片描述
打开dmesg文件可以看到内核转储内容于你触发crash的内容是对的上的

[1212551.621023]  __handle_sysrq.cold.9+0x45/0xec
[1212551.621491]  write_sysrq_trigger+0x2b/0x30
[1212551.621959]  proc_reg_write+0x3c/0x60
[1212551.622426]  vfs_write+0xa5/0x1a0
[1212551.622889]  ksys_write+0x4f/0xb0
[1212551.623369]  do_syscall_64+0x5b/0x1b0
[1212551.623835]  entry_SYSCALL_64_after_hwframe+0x65/0xca
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
posted on 2020-12-14 21:21  pycod  阅读(796)  评论(0编辑  收藏  举报