RHEL7系统管理之内核管理

RHEL7系统管理之内核管理

  1. Kdump工具

  Kdump的干活机制是在幼功崩溃时, 通过kexec 工具由BIOS运维叁个备用水源,
由备用水源试行少年老成多级职责,保存内部存款和储蓄器中崩溃内核的意况, 供后续故障深入分析用.

  本文暗许英特尔或INTEL X86_64框架结构, HavalHEL7连串境况. 

1.1 内核管理工科具Kdump安装

  Kdump是科雷傲HEL7中自带的基业管理工科具.在宝马X5HEL7.1事先的版本,kdump作为安装到位之后的可选组件自动安装,从帕杰罗HEL7.1方始kdump被植入安装界面,作为系统根基工具供安装接受.

能够因此上面指挥若定直接RPM包安装.

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

再就是,Kdump还安插了图形化处理工科具,可以因而上边三令五申安装.

yum -y install system-config-kdump

  对于LANDHEL7.4及之后的本子,kdump援救INTEL IOMMU.
而不扶助F12berlinettaHEL7.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)在OdysseyHEL7此前的版本中,kdump的存放目录会随着kdump服务的开发银行而由系统自动成立.
福特ExplorerHEL7中,假如改换了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的调校门路

  福特ExplorerHEL7中提供二种基本调校方法:

  (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

(2)开启本地ipv4转载成效.

sysctl net.ipv4.ip_forward = 1

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

sysctl vm.max_map_count = 65530

(4)设定系统中何况运行的最大进度数.

sysctl kernel.threads-max = 16161

  在root权限下,通过sysctl 命令的基石参数调校, 基本上能直接调控linux
的木本全体行为举止, 满足实际生育中的绝大多数要求.

  

admin

网站地图xml地图