[转帖]Kdump配置及使用(详细)总结(二)

kdump,配置,使用,详细,总结 · 浏览次数 : 0

小编点评

**Kdump简介** Kdump是一种基于 kexec 的内核崩溃转储机制,用来捕获内核崩溃的时候产生的 crash dump。当内核产生错误时,kdump 会将内存导出为 vmcore 保存到磁盘。 **Kdump整体介绍** 1. **kdump** 是一种 advanced内核崩溃转储机制,用于捕获内核崩溃时产生的 crash dump。 2. **kdump** 流程:当系统崩溃时,kdump 使用 kexec 启动到第二个内核。第二个内核通常称为 **捕获内核**,以很小内存启动以捕获转储镜像。 3. **kdump** 的配置流程如下: * 内核配置安装 kdump(kexec-tools)工具修改内核启动参数修改kdump配置文件启动kdump功能验证Kdump功能 * 安装 kexec-tools 工具 * 修改内核启动参数 * 启动 kdump 服务 **Kdump具体配置** **3.1 内核配置** 通常设备默认内核是已经配置了Kdump 功能的。 **3.2 安装 kexec 工具** ``` yum install kexec-tools ``` **3.3 修改内核启动参数** ``` vim /boot/grub2/grub.cfg ``` 最后添加以下一行: ``` crashkernel=auto ``` **3.4 修改 kdump 配置文件** ``` vim /etc/kdump.conf ``` **3.5 启动 kdump 功能** ``` systemctl enable kdump.service systemctl start kdump.service ``` **3.6 验证 Kdump 功能** ``` echo 1 > /proc/sys/kernel/sysrq echo c > /proc/sysrq-trigger12 ``` 这将模拟系统异常崩溃,验证之前的操作是否都成功了。 **其他相关链接** 1. Kdump调试机理总结(一) 2. crash工具分析vmcore文件常用命令总结(三) 3. grub.cfg配置总结 4. 编译linux内核常见报错总结

正文

一、简介

本文主要介绍如何打开Kdump并对其相关文件进行配置。前面章节已经对Kdump调试机理进行总结总结,具体可以点击下面链接:

Kdump调试机理总结(一)

crash工具分析vmcore文件常用命令总结(三)

二、Kdump整体介绍

1、kdump
kdump 是一种先进的基于 kexec 的内核崩溃转储机制,用来捕获kernel crash(内核崩溃)的时候产生的crash dump。当内核产生错误时,kdump会将内存导出为vmcore保存到磁盘。

2、 kdump流程
当系统崩溃时,kdump 使用 kexec 启动到第二个内核。第二个内核通常叫做捕获内核,以很小内存启动以捕获转储镜像。第一个内核启动时会保留一段内存给kdump用。
在这里插入图片描述

3、kdump的配置流程具体如下:

内核配置
安装kdump(kexec-tools)工具
修改内核启动参数
修改kdump配置文件
启动kdump功能
验证Kdump功能
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

三、Kdump具体配置

3.1 内核配置
通常设备默认内核是已经配置了Kdump功能的。
想要确认当前内核是否支持kexec,可通过查看在/sys/kernel/下有没有kexec等文件去确认,同时通过查看 /sys/kernel/kexec_crash_loaded 的值,判断Kdump功能是否加载(“1”为已经加载,“0”为还未加载)

[root@localhost /]# cat /sys/kernel/kexec_crash_loaded
  • 1

如果没有,则需要我们对内核进行配置,具体如下(make menuconfig):

CONFIG_KEXEC=y
Boot options  --->[*] Kexec system call (EXPERIMENTAL)
//此参数告诉系统使用Kexec跳过BIOS和引导(新)内核。(提供内核层面的kexec功能支持)
CONFIG_CRASH_DUMP=y
Boot options  --->[*] Build kdump crash kernel (EXPERIMENTAL)
//崩溃转储需要启用。没有此选项,Kdump将毫无用处。(提供内核层面的kdump功能支持)
CONFIG_SYSFS=y
File systems  --->Pseudo filesystems  --->[*] Tmpfs virtual memory file system support
//启用sysfs文件系统支持
CONFIG_PROC_VMCORE=y
File systems  --->Pseudo filesystems  --->-*- /proc file system support--->[*]   /proc/vmcore support
//此配置允许Kdump将内存转储保存到/proc/vmcore。
CONFIG_DEBUG_INFO=y
Kernel hacking  --->Compile-time checks and compiler options  --->[*] Compile the kernel with debug info
//此参数表示将使用调试符号构建内核。尽管这将增加内核映像的大小,但是具有可用的符号对于深入分析内核崩溃非常有用,因为它不仅使您可以跟踪导致崩溃的有问题的函数调用问题,而且可以跟踪特定行在相关来源中。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

3.2 安装kdump(kexec-tools)工具

[root@localhost /]# yum install kexec-tools
//安装完成之后可以通过kexec -v查看kexec的版本
  • 1
  • 2

3.3 修改内核启动参数
(1)直接配置

[root@localhost /]# vim /boot/grub2/grub.cfg
//直接在加载内核这一行(linux ${prefix}/vmlinuz console=tty  xxx)最后加上crashkernel=auto
//auto为自动根据内存分配vmcore的生成的大小,也可以指定具体大小,如crashkernel=128M,具体grub.cfg的配置可以查看本人博客:
  • 1
  • 2
  • 3

grub.cfg配置总结

(2)通过工具重置grub.cfg

[root@localhost /]#  vim /etc/default/grub
  • 1

修改为

GRUB_CMDLINE_LINUX="crashkernel=auto" //自动分配大小,部分系统需要指定固定大小
  • 1

说明:
crashkernel=xxx //预留内存大小
注意:
注意预留内存大小,过大/过小都会导致生成vmcore文件失败(不知道设置多少时,可以尝试每次增加128M)

[root@localhost /]#  grub2-mkconfig -o /boot/grub2/grub.cfg
  • 1

(3)重启确认配置是否成功

[root@localhost /]# reboot
[root@localhost /]# cat /proc/cmdline 
BOOT_IMAGE=/vmlinuz-4.4.13-200.nd7.3.x86_64 root=/dev/sda3 ro rhgb quiet loglevel=0 LANG=zh_CN.UTF-8 crashkernel=auto
  • 1
  • 2
  • 3

说明:
如果在cmdline里找到了crashkernel参数,代表已经将配置写入内核了.

3.4 修改kdump配置文件

[root@localhost /]#  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

3.5 启动kdump功能

[root@localhost /]#  systemctl enable kdump.service
[root@localhost /]#  systemctl start kdump.service
[root@localhost 桌面]# systemctl status kdump.service
● kdump.service - Crash recovery kernel arming
   Loaded: loaded (/usr/lib/systemd/system/kdump.service; disabled)
   Active: active (exited) since 四 2022-05-05 19:12:31 CST; 1min 14s ago
  Process: 2272 ExecStart=/usr/bin/kdumpctl start (code=exited, status=0/SUCCESS)
 Main PID: 2272 (code=exited, status=0/SUCCESS)
   CGroup: /system.slice/kdump.service

505 19:12:31 localhost kdumpctl[2272]: kexec: loaded kdump kernel
505 19:12:31 localhost kdumpctl[2272]: Starting kdump: [OK]

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

注意:
本人在用x86的系统打开kdump服务时,指定的crashkernel=auto不生效,导致启动失败,可以用crashkernel=128M@48M格式测试;

3.6 验证Kdump功能
我们来模拟系统异常崩溃,验证之前的操作是否都成功了:

[root@localhost /]# echo 1 > /proc/sys/kernel/sysrq
[root@localhost /]# echo c > /proc/sysrq-trigger
  • 1
  • 2

重启后,查看/var/crash目录

[root@localhost /]# ls /var/crash/
  • 1

保留内存是否预留成功,可以通过cat /proc/meminfo查看。

[root@localhost /]# cat /proc/meminfo | grep Crash
  • 1

四、其他相关链接

1、Kdump调试机理总结(一

2、crash工具分析vmcore文件常用命令总结(三)

3、grub.cfg配置总结

4、编译linux内核常见报错总结

</article>

与[转帖]Kdump配置及使用(详细)总结(二)相似的内容:

[转帖]Kdump配置及使用(详细)总结(二)

一、简介 本文主要介绍如何打开Kdump并对其相关文件进行配置。前面章节已经对Kdump调试机理进行总结总结,具体可以点击下面链接: Kdump调试机理总结(一) crash工具分析vmcore文件常用命令总结(三) 二、Kdump整体介绍 1、kdump kdump 是一种先进的基于 kexec

[转帖]Kdump调试机理详细总结(一)

https://blog.csdn.net/luckiers/category_11796393.html 一、简介 本文主要讲解Kdump的运行机理,后续两个章节会详细介绍kdump的使用和如何分析coredump文件信息,具体链接如下: Kdump配置及使用详细总结(二) crash工具分析vm

[转帖]crash工具分析Kdump下vmcore文件常用命令总结(三)(实例易懂)

一、简介 本文主要介绍使用crash工具对kdump生成的vmcore文件进行分析,解析常见的crash命令,前面已讲述两章关于Kdump的内容,读者感兴趣可以点击下面的链接: 1、Kdump调试机理总结(一) 2、Kdump配置及使用详细总结(二) 系统产生异常时,触发Kdump机制,启动捕获内核

[转帖]

Linux ubuntu20.04 网络配置(图文教程) 因为我是刚装好的最小系统,所以很多东西都没有,在开始配置之前需要做下准备 环境准备 系统:ubuntu20.04网卡:双网卡 网卡一:供连接互联网使用网卡二:供连接内网使用(看情况,如果一张网卡足够,没必要做第二张网卡) 工具: net-to

[转帖]

https://cloud.tencent.com/developer/article/2168105?areaSource=104001.13&traceId=zcVNsKTUApF9rNJSkcCbB 前言 Redis作为高性能的内存数据库,在大数据量的情况下也会遇到性能瓶颈,日常开发中只有时刻

[转帖]ISV 、OSV、 SIG 概念

ISV 、OSV、 SIG 概念 2022-10-14 12:29530原创大杂烩 本文链接:https://www.cndba.cn/dave/article/108699 1. ISV: Independent Software Vendors “独立软件开发商”,特指专门从事软件的开发、生产、

[转帖]Redis 7 参数 修改 说明

2022-06-16 14:491800原创Redis 本文链接:https://www.cndba.cn/dave/article/108066 在之前的博客我们介绍了Redis 7 的安装和配置,如下: Linux 7.8 平台 Redis 7 安装并配置开机自启动 操作手册https://ww

[转帖]HTTPS中间人攻击原理

https://www.zhihu.com/people/bei-ji-85/posts 背景 前一段时间,公司北京地区上线了一个HTTPS防火墙,用来监听HTTPS流量。防火墙上线之前,邮件通知给管理层,我从我老大那里听说这个事情的时候,说这个有风险,然后意外地发现,很多人原来都不知道HTTPS防

[转帖]关于字节序(大小端)的一点想法

https://www.zhihu.com/people/bei-ji-85/posts 今天在一个技术群里有人问起来了,当时有一些讨论(不完全都是我个人的观点),整理一下: 为什么网络字节序(多数情况下)是大端? 早年设备的缓存很小,先接收高字节能快速的判断报文信息:包长度(需要准备多大缓存)、地

[转帖]awk提取某一行某一列的数据

https://www.jianshu.com/p/dbcb7fe2da56 1、提取文件中第1列数据 awk '{print $1}' filename > out.txt 2、提取前2列的文件 awk `{print $1,$2}' filename > out.txt 3、打印完第一列,然后打