必赢的网址登录 > 必赢娱乐 > 客户空间的软件包"kexec-tools"必赢的网址登录使用

原标题:客户空间的软件包"kexec-tools"必赢的网址登录使用

浏览次数:103 时间:2019-09-30

  1. Kdump工具

什么是Kdump?

Kdump是贰个基于kexec的内核崩溃转储机制,当系统崩溃时,kdump使用kexec运维到第一个基本。地球热能个基本叫做捕获内核可能又叫“2nd kernel”,它以少之又少的内部存款和储蓄器运行捕获内核,并抓获转储镜像。Kdump的定义是当前最可靠的基石转储技能,已被注重的linux商家使用。(比如Red Hat类别)

  Kdump的干活机制是在基础崩溃时, 通过kexec 工具由BIOS运转二个备用水源, 由备用水源实施一体系职分,保存内存中崩溃内核的景观, 供后续故障分析用.

什么是Kexec?

Kexec是一种能够遵照已经运转基本的上下文快快捷运输行新水源的一种机制,而不通过BIOS。BIOS的运营在一部分特大型机械大概有恢宏外设的机械上时特意耗费时间。这种体制能够节省须要在分裂基础之间切换的开拓人士的光阴。
Kexec在基本空间和顾客空间都有对应的机件,内核提供了多少个kexec重启功用的种类调用。客户空间的软件包"kexec-tools"使用那么些系统调用,并推行加载和辅导第贰个水源(捕获内核)。
Kexec由两片段构成,一是根本空间的系统调用kexec_load,负担在生产基础(或然叫第二个基础)运维时将捕获内核(恐怕叫第三个水源)加载到钦定的职位。而是客户空间的kexec-tools,它将捕获内核(second kernel)的地址传递给生产基础(first kernel),让系统在崩溃的时候能够找到捕获内核(second kernel)的地方并运维。

  本文暗中认可英特尔或INTEL X86_64架构, PAJEROHEL7连串环境. 

Kdump怎么职业?

在现阶段系统产生崩溃时,新的破获内核被加载,然后根据已安装的下令去将眼下事先发生崩溃的类其余内部存款和储蓄器保存到八个特别的文本(vmcore)中。

上面以Fedora26做为测量试验演示。(Fedora和CentOS体系的连串现已在kenrel中开发了CONFIG_KEXEC*选项。)

首先须求在系统运转时留下出给第一个基本运维的内存。内核参数"crashkernel=160M"会在系统运营时留下出160M内存的长空给捕获内核运转使用。"crashkerel=xM"还支持任何的参数,详细的能够参谋内核参数文书档案 水源参数。

# dmesg | grep -i reserving
[    0.000000] Reserving 160MB of memory at 656MB for crashkernel (System RAM: 2047MB)

系统运营后大家能够从上边的命令中看出曾经预留出了160M的内部存款和储蓄器从内部存款和储蓄器的656M处。

安装客商态的包"kexec-tools",软件包中会提供kdump所需的劳动和"kexec"急速内核运转命令,和压缩过滤内部存款和储蓄器的"makedumpfile"命令。

[root@localhost ~]# dnf install -y kexec-tools

布局,修改kdump相关的布局文件。

[root@localhost ~]# grep -v ^# /etc/kdump.conf 

path /var/crash
core_collector makedumpfile -l --message-level 1 -d 31


[root@localhost ~]# grep -v ^# /etc/sysconfig/kdump
KDUMP_KERNELVER=""

KDUMP_COMMANDLINE=""

KDUMP_COMMANDLINE_REMOVE="hugepages hugepagesz slub_debug quiet"

KDUMP_COMMANDLINE_APPEND="irqpoll nr_cpus=1 reset_devices cgroup_disable=memory mce=off numa=off udev.children-max=2 panic=10 rootflags=nofail acpi_no_memhotplug transparent_hugepage=never nokaslr"

KEXEC_ARGS=""

KDUMP_IMG="vmlinuz"

KDUMP_IMG_EXT=""

安顿文件/etc/kdump.conf设置了kdump发生时vmcore文件的积累格局,此文件修改后供给重启kdump的服务。

配备文件/etc/sysconfig/kdump,要是只是修改了COMMANDLINE相关的参数,则无需去重新build生成新的initramfs文件。

启动kdump服务:

[root@localhost ~]# systemctl restart kdump
[root@localhost ~]# systemctl status kdump
● kdump.service - Crash recovery kernel arming
   Loaded: loaded (/usr/lib/systemd/system/kdump.service; enabled; vendor preset: disabled)
   Active: active (exited) since Sat 2017-07-15 10:46:22 UTC; 36s ago
  Process: 2172 ExecStop=/usr/bin/kdumpctl stop (code=exited, status=0/SUCCESS)
  Process: 2180 ExecStart=/usr/bin/kdumpctl start (code=exited, status=0/SUCCESS)
 Main PID: 2180 (code=exited, status=0/SUCCESS)

Jul 15 10:46:21 localhost dracut[4264]: -rw-r--r--   1 root     root          127 Mar 28 02:15 usr/share/zoneinfo/Etc/UTC
Jul 15 10:46:21 localhost dracut[4264]: drwxr-xr-x   3 root     root            0 Jun 22 13:38 var
Jul 15 10:46:21 localhost dracut[4264]: lrwxrwxrwx   1 root     root           11 Jun 22 13:38 var/lock -> ../run/lock
Jul 15 10:46:21 localhost dracut[4264]: lrwxrwxrwx   1 root     root            6 Jun 22 13:38 var/run -> ../run
Jul 15 10:46:21 localhost dracut[4264]: drwxr-xr-x   2 root     root            0 Jun 22 13:38 var/tmp
Jul 15 10:46:21 localhost dracut[4264]: ========================================================================
Jul 15 10:46:21 localhost dracut[4264]: *** Creating initramfs image file '/boot/initramfs-4.11.9-300.fc26.x86_64kdump.img' done ***
Jul 15 10:46:22 localhost kdumpctl[2180]: kexec: loaded kdump kernel
Jul 15 10:46:22 localhost kdumpctl[2180]: Starting kdump: [OK]
Jul 15 10:46:22 localhost systemd[1]: Started Crash recovery kernel arming.

不无的劳务都配置完毕,假若那时候系统产生了panic大概别的的有的导致系统崩溃的情景,那是kdump服务会将立即的内存镜像依据客商的安顿保存起来。三个归纳的措施是经过命令来触发:

[root@localhost ~]# echo c > /proc/sysrq-trigger

[some console log]
... ...
         Starting Kdump Vmcore Save Service...
kdump: dump target is /dev/vda1
kdump: saving to /sysroot//var/crash/127.0.0.1-2017-07-16-04:21:36/
[    2.718001] EXT4-fs (vda1): re-mounted. Opts: data=ordered
kdump: saving vmcore-dmesg.txt
kdump: saving vmcore-dmesg.txt complete
kdump: saving vmcore
Copying data                       : [100.0 %] -
kdump: saving vmcore complete
... ...
[/some console log]

当系统重启后就能够在钦点的目录下见到变化的vmcore文件。能够参见布局文件"/etc/kdump.conf"里的"path"字段。

[root@localhost ~]# ls -lt /var/crash/*/
total 33492
-rw-------. 1 root root 34253115 Jul 16 04:21 vmcore
-rw-r--r--. 1 root root    40360 Jul 16 04:21 vmcore-dmesg.txt

转储文件被封存后得以用"crash"这一个软件包来深入分析那么些"vmcore"文件。

发端波及了Kexec内核部分提供了有个别系统调用,"kexec_load()" 和 "kexec_file_load()",个中一个用来加载捕获内核 - "kexec -l",别的多个来提供系统重启 - "kexec -e"。

系统调用"kexec_load()"能够加载贰个新的水源并随后能够被"reboot()"调用。它是被如此定义的:

long kexec_load(unsigned long entry, unsigned long nr_segments,
                       struct kexec_segment *segments, unsigned long flags);

里面二个相比较重要的是"kexec_segment"结构体:

struct kexec_segment {
    void   *buf;        /* Buffer in user space */
    size_t  bufsz;      /* Buffer length in user space */
    void   *mem;        /* Physical address of kernel */
    size_t  memsz;      /* Physical address length */
};

当reboot()的参数为"LINUX_REBOOT_CMD_KEXEC"并被调用时,则运营新的内核时就调用"kexec_load()"系统调用。别的“CONFIG_KEXEC”必需在编写翻译kernel时被展开。

系统调用"kexec_load_file()"会安装2个参数"kernel"和"initramfs"给"kexec"命令。"kexec"会读取那么些多少来创建对应的数据段。

long kexec_file_load(int kernel_fd, int initrd_fd,
                           unsigned long cmdline_len, const char *cmdline,
                           unsigned long flags);

同样的"CONFIG_KEXEC_FILE"参数也要在基本编写翻译时被打开。

当下的大部发行版都已经开荒了"KEXEC"相关的陈设参数。

以上就是二个kdump的简便流程。有关"kdump"能够捕获到的内核崩溃时间能够参照他事他说加以考察文书档案"/usr/share/doc/kexec-tools/kexec-kdump-howto.txt"。恐怕请参照他事他说加以考察大家写的测量试验用例 kdump-test。

参谋资料:
kdump-paper
kdump-introduction
fedora-kexec-tools

1.1 内核管理工科具Kdump安装

  Kdump是酷威HEL7中自带的基本管理工科具.在SportageHEL7.1事先的版本,kdump作为安装到位之后的可选组件自动安装,从CR-VHEL7.1发端kdump被植入安装分界面,作为系统基础工具供安装选用.

可以通过上面发号施令间接RPM包安装.

yum -y install kexec-tools
rpm -q kexec-tools

並且,Kdump还安插了图形化管理工科具,能够通过下边发号施令安装.

yum -y install system-config-kdump

  对于汉兰达HEL7.4及之后的本子,kdump帮助INTEL IOMMU. 而不支持OdysseyHEL7.3及从前的版本.

1.2 通过命令行配置kdump内部存款和储蓄器容积

  kdump能监督连串基本运生势况,其身份相比较特殊. kdump的内部存款和储蓄器空间是在系统运维时,由指点程序分配的,相对于系统基本,kdump内部存款和储蓄器是一个独门的空间.

能够通过如下命令内定kdump的内部存款和储蓄器空间大小.

crashkernel=128M     #为kdump保留128M的内存空间.

   crashkernel的值能够设置成“auto",在部分独具一点都不小内部存储器的连串中,利于达成Kdump的自动化管理.

crashkernel=auto

  当然,crashkernel的值还足以经过如下方式落实更加灵敏的配置.

  crashkernel=<范围1>:<大小1>, <范围2>:<大小2>

crashkernel=512M-2G:64M,2G-:128M    #当系统内存在512M-2G之间时,为Kdump保留64M的内存空间;当系统内存大于2G时,为Kdump保留128M的内存空间.

  还足以如此:

crashkernel=128M@16M    #为Kdump保留128M的内存空间,内存地址从16M(physical address 0x01000000)开始.

1.3 Kdump的存储

  Kdump的配备在/etc/kdump.cnf中. kdump提供种种格局将捕获到基础崩溃数据当地保存或保存到长途主机.

#path /var/crash    #kdump本地存储目录,默认是存放在/var/crash目录下,可以根据使用习惯设置.
path /usr/local/cores 
...
#raw /dev/vg/lv_kdump    #kdump可以直接写入移动介质.
raw /dev/sdb1
...
#nfs my.server.com:/export/tmp    #kdump可以通过NFS保存到网络上其它存储设备中.
nfs test.example.com:/export/cores
...
#ssh user@my.server.com      #kdump可以通过SSH传输协议,保存远程主机上.
#sshkey /root/.ssh/kdump_id_rsa
ssh user@test.example.com
sshkey /root/.ssh/mykey

  kdump.conf中还足以在 core_collector makedumpfile 选项后增加" -c ", 使kdump文件能够被减去,以节约存款和储蓄空间.

core_collector makedumpfile -c

systemctl start kdump.service    #启动Kdump服务
systemctl enable kdump.service    #使Kdump开机自启
systemctl is-active kdump       #检查Kdump是否已启动
active
echo 1 > /proc/sys/kernel/sysrq   #模拟内核崩溃,检查/var/crash/是否自动保存Kdump捕获的内核崩溃数据, 以确定Kdump是否正常工作
echo c > /proc/sysrq-trigger

  供给介意的是

  (1)在PRADOHEL7在此以前的本子中,kdump的存放目录会随着kdump服务的运转而由系统活动创制. 奔驰M级HEL7中,假若改换了kdump的囤积目录,则必需在起步kdump服务从前,手动创设kdump的存款和储蓄目录,不然kdump服务会运转失利.

  (2)倘诺在安装分界面禁止使用了kdump, 而安装到位之后再经过systemctl start kdump运转kdump, 会报内部存储器不足不可能起动的错误. kdump的内存空间是在根本加载此前由boot分配的, 所以必需修改boot. 最棒应用kdump的图形处理工科具 system-config-kdump 加载kdump的暗中认可配置, 使kdump处于可用状态, 然后重启系统, systemctl status kdump 服务处于激活状态(active).

1.4 利用crash效率剖析内核崩溃

  利用crash功能组件能够深入分析linux内核崩溃时的互连网、磁盘、CPU、系统基本状态,急迅稳固故障点.

crash组件能够经过RPM包安装.

sudo yum -y install crash       #安装crash
sudo debuginfo-install kernel    #安装内核调试模块

 sudo crash /usr/lib/debug/lib/modules/<kernel>/vmlinux /var/crash/<timestamp>/vmcore  #启动crash调试

测量试验一下:

必赢的网址登录 1

必赢的网址登录 2

crash基本调节和测量检验命令:

crash>log    #崩溃时日志记录
crash>bt     #崩溃时的堆栈信息
crash>vm     #崩溃时的内存状态
crash>ps     #崩溃时的进程状态
crash>files   #崩溃时的打开的文件
crash>exit   #退出crash

2 linux内核调校

2.1 kernel的调校渠道

  奥德赛HEL7中提供三种基本调校方法:

  (1)使用sysctl 命令;

  (2)修改/etc/sysctl.d/ 目录下的基础配置文件;

  (3)通过shell 在/proc/sys 目录下挂载设想文件系统;

2.2 sysctl命令能够列出、读取、设置基础参数, 还足以将参数设置为一时或恒久.

sysctl -a        #列出所有可调校的项
sysctl kernel.version    #列出kernel的版本信息

sysctl <tunable class>.<tunable>=<value>       #使调校参数临时生效
sysctl -W <tunable class>.<tunable>=<value>   #使调校参数永久生效

2.3 修改/etc/sysctl.d/99-sysctl.conf 目录下的99-sysctl.conf文件

cp /etc/sysctl.d/99-sysctl.conf /etc/sysctl.d/99-sysctl.conf.bak    #备份系统默认的内核参数文件
vim /etc/sysctl.d/99-my.conf    #创建新的内核参数文件

...
<tunable class>.<tunable> = <value>   #写入要调校的参数类和值
 <tunable class>.<tunable> = <value>
...
save    #保存文件
reboot sysctl -p /etc/sysctl.d/99-my.conf  #重启系统或者使用sysctl -p 命令载入新的内核参数配置

2.4 sysctl 调校内核参数

(1)调度最大央浼的aio数量.

sysctl -a | grep fs.aio    #查看内核默认的最大aio值
sysctl fs.aio-max-nr=2048576  #临时调整aio最大值

必赢的网址登录 3

客户空间的软件包"kexec-tools"必赢的网址登录使用那一个体系调用,1.1 内核管理工科具Kdump安装。(2)开启本地ipv4转载作用.

sysctl net.ipv4.ip_forward = 1

(3)设定进程能被分配到的最大内部存款和储蓄器空间.

sysctl vm.max_map_count = 65530

(4)设定系统中並且运营的最大进程数.

sysctl kernel.threads-max = 16161

  在root权限下,通过sysctl 命令的木本参数调校, 基本上能一直调节linux 的水源全数行为, 满意实际生产中的绝大好些个须求.

  

本文由必赢的网址登录发布于必赢娱乐,转载请注明出处:客户空间的软件包"kexec-tools"必赢的网址登录使用

关键词:

上一篇:VSportage SDK的VENVISION图形优化,1.对此任何的Blue

下一篇:兼容SysV和LSB的启动脚本,必赢的网址登录3、LV