进程管理
引用:linux工具快速教程:https://linuxtools-rst.readthedocs.io/zh_CN/latest/index.html#
1、查询正在运行的进程信息
$ps -ef
eg:查询归属于用户colin115的进程
$ps -ef | grep colin115
$ps -lu colin115
2、查询进程ID(适合只记得部分进程字段)
$pgrep 查找进程
eg:查询进程名中含有re的进程
[/home/weber#]pgrep -l re
2 kthreadd
28 ecryptfs-kthrea
29515 redis-server
3、以完整的格式显示所有的进程
$ps -ajx
4、显示进程信息,并实时更新
$top
5、查看端口占用的进程状态:
lsof -i:3306
6、查看用户username的进程所打开的文件
$lsof -u username
7、查询init进程当前打开的文件
$lsof -c init
8、查询指定的进程ID(23295)打开的文件
$lsof -p 23295
9、查询指定目录下被进程开启的文件(使用+D 递归目录)
$lsof +d mydir1/
10、杀死指定PID的进程 (PID为Process ID)
$kill PID
11、杀死相关进程
kill -9 3434
12、杀死job工作 (job为job number)
$kill %job
13、查看系统中使用CPU、使用内存最多的进程;
$top
(->)P
输入top命令后,进入到交互界面;接着输入字符命令后显示相应的进程状态:
对于进程,平时我们最常想知道的就是哪些进程占用CPU最多,占用内存最多。以下两个命令就可以满足要求::
P:根据CPU使用百分比大小进行排序。
M:根据驻留内存大小进行排序。
i:使top不显示任何闲置或者僵死进程。
14、使用命令pmap,来输出进程内存的状况,可以用来分析线程堆栈;
$pmap PID
eg:
[/home/weber#]ps -fe| grep redis
weber 13508 13070 0 08:14 pts/0 00:00:00 grep --color=auto redis
weber 29515 1 0 2013 ? 02:55:59 ./redis-server redis.conf
[/home/weber#]pmap 29515
29515: ./redis-server redis.conf
08048000 768K r-x-- /home/weber/soft/redis-2.6.16/src/redis-server
08108000 4K r---- /home/weber/soft/redis-2.6.16/src/redis-server
08109000 12K rw--- /home/weber/soft/redis-2.6.16/src/redis-server
15、综合运用
将用户colin115下的所有进程名以av_开头的进程终止
ps -u colin115 | awk '/av_/ {print "kill -9 " $1}' | sh
将用户colin115下所有进程名中包含HOST的进程终止
ps -fe| grep colin115|grep HOST |awk '{print $2}' | xargs kill -9;