CentOS7配置kdump
阅读原文时间:2023年07月08日阅读:1

CentOS7配置kdump

简单生活,简单爱 2020-10-27 16:29:56  56  收藏 1

分类专栏: Linux实际开发总结

版权

文章目录

  • * 1.kdump简介

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

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

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

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

  • (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