Linux进程管理和服务控制小结(4-4 进程查看与控制)
Linux进程管理和服务控制视频课程
http://edu.51cto.com/course/course_id-2923.html
吴忠捷 老师
索罗看完教程,受教颇多,做笔记如下:
1、ps 显示瞬间进程的状态
常用的参数格式
ps aux //列出目前所有的正在内存当中的程序
ps -elf
参数:
-A :所有的进程均显示出来,与 -e 具有同样的效用;
-a : 显示现行终端机下的所有进程,包括其他用户的进程;
-u :以用户为主的进程状态 ;
x :通常与 a 这个参数一起使用,可列出较完整信息。
输出格式规划:
l :较长、较详细的将该 PID 的的信息列出;
j :工作的格式 (jobs format)
-f :做一个更为完整的输出。
特别说明:
由于 ps 能够支持的系统类型相当的多,所以他的参数多的离谱。呵呵,感觉没有必要对所有的参数进行详记细查。
另外有没有加上 – 差很多!强迫症的同学可man一下。
看几个例子吧:
ps -l
标题字母的含义解析:
F 代表这个程序的旗标 (flag), 4 代表使用者为 superuser root;
S 代表这个程序的状态 (STAT);S表示休眠(sleep),s表示父进程,R表示运行(运行),Z表示僵尸进程,+表示前台运行,
STAT栏中的含义:D 不可中断 Uninterruptible(usually IO)
R 正在运行,或在队列中的进程
S 处于休眠状态
T 停止或被追踪
Z 僵尸进程
W 进入内存交换(从内核2.6开始无效)
X 死掉的进程对于BSD格式,还可能会显示:
< 高优先级
n 低优先级
L 分页在内存中锁定(对于实时和自定义IO)
s 包含子进程
l 多线程(使用CLONE_THREAD,类似NPTL线程)
+ 位于前台的进程组
UID 代表执行者身份ID
PID 进程的ID号!底下的 PPID 则父进程的ID;
C CPU 使用的资源百分比
PRI指进程的执行优先权(Priority的简写),其值越小越早被执行;
NI 这个进程的nice值,其表示进程可被执行的优先级的修正数值。
ADDR 这个是内核函数,指出该程序在内存的那个部分。如果是个执行的程序,一般就是『 – 』
SZ 使用掉的内存大小;
WCHAN 目前这个程序是否正在运作当中,若为 – 表示正在运作;
TTY 登入者的终端机位置;
TIME 使用掉的 CPU 时间。
CMD 所下达的指令名称
ps aux
USER:该进程属于那个使用者账号的
PID :该进程的进程ID号。
%CPU:该进程使用掉的 CPU 资源百分比;
%MEM:该进程所占用的物理内存百分比;
VSZ :该进程使用掉的虚拟内存量 (Kbytes)
RSS :该进程占用的固定的内存量 (Kbytes)
TTY :该进程是在那个终端上面运作,若与终端无关,则显示 ?,另外, tty1-tty6 是本机上面的登入者程序,若为 pts/0 等等的,则表示为由网络连接进主机的程序。
STAT:该程序目前的状态,主要的状态有:
R :该程序目前正在运作,或者是可被运作;
S :该程序目前正在睡眠当中 ,但可被某些信号唤醒。
T :该程序目前正在侦测或者是停止了;
Z :该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
START:该进程被触发启动的时间;
TIME :该进程实际使用 CPU 运作的时间。
COMMAND:该程序的实际指令名称
2、top 显示动态进程的状态
3、pgrep 根据特定条件查看进程PID信息
pgrep migration 查看migration 占用的进程号,
pgrep -l migration 以详细的方式查看服务migration进程占用情况
pgrep -U root -t pts/0 -l 查看root用户在pts/0 上起来的进程详细信息。
-U 用户
-t 终端 ,可以tty1,tty2,。。。。或者pts/0,pts/1 等等。 tty是本地的终端,pts是通过网络方式登录进来的。
pgrep -l “log”
查看在运行进程中包含字母“log”的所有进程。
4、pstree 查看进程树信息
前面在 http://www.netzg.net/793.html 中已经做了简洁的介绍,在此再补充点信息吧。
pstree -aup
5、启动进程的方法
前台启动:用户直接输入命令,启动服务/程序即可。
后台启动:方法类似前台启动,不过需要在命令后加“&”符号。
6、结束进程的方法
前台进程结束用ctrl+c即可。
后台进程要用到kill或者killall
kill 用于终止指定进程号的进程。
killall 用于终止指定名称的所有进程。
-9 选项用于强制终止。
kill 后面是要加进程号的,不能接进程名字。
pkill 用以特定的条件结束相应的进程。
pgrep -l -U “heike” //查看所有用户heike启动的进程
pkill -9 -U “heike” //关闭所有用户heike启动的进程。