引言
今天再一次体验整个cpu 占满的问题, 并且究其根本,寻找问题所在, 真的是欲哭无泪了, 太难了!
-
第一次没有太在意, 重启了服务器好像好了那么一阵, 最近呢,又往服务器上部署了项目, 今天终于又一次复现了.
排查问题如果通过 **top** 等监控发现 kswapd0 进程持续处于非睡眠状态,且运行时间较长并持续占用较高 CPU 资源, 则通常是由于系统在持续的进行换页操作所致。则可以通过 **free -m** 、**ps** 等指令进一步查询系统及系统内进程的内存占用情况,做进一步排查分析。
-
根据监控性能显示, kswapd0 占用了大量的cpu资源, 内存本身又没有达到饱和,.所以总结问题如下
A. swap分区的作用是当物理内存不足时,会将一部分硬盘当做虚拟内存来使用。
B. kswapd0 占用过高是因为 物理内存不足,使用swap分区与内存频繁的换页操作交换数据,进而出现了大量的IO, 导致CPU占用过高。
临时解决办法:
查看 swappiness 默认是60, 这个交换参数控制内核从物理内存移出进程,移到交换空间。
该参数从0到100,当该参数=0,表示只要有可能就尽力避免交换进程移出物理内存;该参数=100,
这告诉内核疯狂的将数据移出物理内存移到swap缓存中。
- 所以通过修改参数, (这里我设置的是10, 也可以直接设置0) ,来减少内存和分区的的切换.
[root@elk ~ ]# sysctl vm.swappiness=10 # 修改参数
[root@elk ~ ]# sysctl -p # 查看内容