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

ps1

 

标题字母的含义解析:

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

ps2

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 显示动态进程的状态

top

 

3、pgrep 根据特定条件查看进程PID信息

pgrep

pgrep migration  查看migration 占用的进程号,

pgrep -l migration  以详细的方式查看服务migration进程占用情况

pgrep1

 

pgrep -U root -t pts/0 -l  查看root用户在pts/0 上起来的进程详细信息。

-U  用户

-t  终端  ,可以tty1,tty2,。。。。或者pts/0,pts/1 等等。 tty是本地的终端,pts是通过网络方式登录进来的。

pgrep2

 

pgrep -l “log”

查看在运行进程中包含字母“log”的所有进程。

4、pstree 查看进程树信息

前面在 http://www.netzg.net/793.html 中已经做了简洁的介绍,在此再补充点信息吧。

pstree -aup

pstree

 

5、启动进程的方法

前台启动:用户直接输入命令,启动服务/程序即可。

后台启动:方法类似前台启动,不过需要在命令后加“&”符号。

6、结束进程的方法

前台进程结束用ctrl+c即可。

后台进程要用到kill或者killall

kill  用于终止指定进程号的进程。

killall 用于终止指定名称的所有进程。

-9 选项用于强制终止。

kill 后面是要加进程号的,不能接进程名字。

pkill 用以特定的条件结束相应的进程。

pgrep -l -U “heike”       //查看所有用户heike启动的进程

pkill -9 -U “heike”       //关闭所有用户heike启动的进程。

 

 

yantaisolo

作者 yantaisolo