Linux杀不死的进程之CPU使用率700%

  • 时间:
  • 浏览:1

i. 发现有个程序运行池池CPU使用率你以为700%,COMMAND 是一点随机的字符串组成,完了~ 中标了;第一想到也不“沙雕”它,kill 命令给我上。

[root@zwlbs3 ~]# kill -9 "PID"

ii. 但会 发现 kill 该程序运行池池平静一会后又启动了。

注:老图复用,PID、COMMAND 前要变化。

[root@zwlbs3 ~]# cd /proc/748/
[root@zwlbs3 748]# ls -ial

# "748"是该程序运行池池的 PID,根据你的 PID 来查看即可。

如图:

发现该程序运行池池是在 /dev/shm 目录下的,/dev/shm 是一个 那此目录呢?

从网上摘下来一段一点人解一下 /dev/shm

1) 首先并能看出来/dev/shm是一个 设备文件, 并能把/dev/shm看作是系统内存的入口, 并能把它看做是一块物理存储设备,一个 tmp filesystem, 你并能通过你这人 设备向内存中读写文件, 以加快一点I/O高的操作,比如对一个 大型文件频繁的open, write, read。

2) 据说oracle就利用了/dev/shm(shitou没用过oracle), 并能通过mount命令列出当前的/dev/shm的挂载的文件系统。

3)  既然是基于内存的文件系统,系统重启后/dev/shm下的文件就不所处了。Linux默认(CentOS)/dev/shm分区的大小是系统物理内存的3000%, 虽说使用/dev/shm对文件操作的强度单位会高也不有。但会 目前各发行软件中却很少有使用它的(除了前面提到的Oracle), 并能通过ls /dev/shm查看下面是算不算有文件, 不可能 没有 也不明当前系统并没有 使用该设备。

查看 /dev/shm 目录的有没有 相关文件

[root@zwlbs3 ~]# ls -a /dev/shm/
.  ..

# 没有

任何相关的文件,奇怪了。
  • crontab 也没有 相关计划任务。
  • 使用 which 命令也没有 找到相关的文件。
  • 查看系统日志也是正常,非常奇怪。
  • 几乎没有 找到该程序运行池池相关的文件。

i. 查看某个程序运行池池结构程序运行池占用状况分析

[root@zwlbs3 ~]# top -H -p "PID"

ii. 一个 有太多相关的程序运行池池,删改 kill 掉

iii. 过来几分钟再次检查,发现系统负载恢复正常

本以为除理了,结果过了有几只小时检查发现又出现了,该死的。

不可能 生产环境不方便重启服务器,被逼无奈状况下只好试试 重启大法 了。

重启服务器后一个 小时,再次检查不可能 恢复正常了,还是 重启大法 好使。

  • 该恶意程序运行池池有那此作用?为什么会么会会么会会只消耗CPU资源?不可能 未找到相关文件信息,意味也暂时未清楚。
  • 知道的大佬麻烦我想知道一下,非常感谢!