Linux下批量Kill多个进程
今天发现系统内存占用很严重,系统126g内存,显示只空闲1g
free -g
使用top指令查看,发现进程编号pid为4655的占用内存很严重
ps aux|grep 4655
发现进程号4655对应的是一个spark进程任务(DataSQC)>>>>>结合实际情况,最可能原因是由于spark任务执行完成后,没有调用stop()函数,导致该内存资源一直被占用着。于是,执行kill -9 4655杀掉该进程,然后看内存是否恢复了。
由图可以发现内存收回了1g。由于该任务每天都要执行一次,这就怀疑是否存在大量的该任务进程一直在占用着内存资源,用一下命令查找全部DataSQC任务进程信息:
ps aux|grep DataSQC
好家伙,发现好多~~~
打印出所有DataSQC有关的进程号PID
ps -ef|grep DataSQC|grep -v grep|cut -c 9-15
杀掉所有相关的进程
ps -ef|grep DataSQC|grep -v grep|cut -c 9-15|xargs kill -9
执行完之后,再次查看内存占用情况,发现剩余内存回收到了50g~
问题解决!
指令说明:
ps -ef|grep DataSQC|grep -v grep|cut -c 9-15|xargs kill -9
管道符"|"用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入。下面说说用管道符联接起来的
几个命令:
- "ps - ef"是linux 里查看所有进程的命令。这时检索出的进程将作为下一条命令"grep DataSQC"的输入。
- "grep DataSQC"的输出结果是,所有含有关键字"DataSQC"的进程。
- "grep -v grep"是在列出的进程中去除含有关键字"grep"的进程。
- "cut -c 9-15"是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。
- "xargs kill -9"中的xargs命令是用来把前面命令的输出结果(PID)作为"kill -9"命令的参数,并执行该令。