Linux中进程分类
①交互进程:由一个shell启动的进程,交互进程既可以在前台运行,也可以在后台运行。
②批处理进程:这种进程和终端没有联系,是一个进程序列。
③监控进程:也称守护进程,是一个在后台运行且不受任何终端控制的特殊进程,用于执行特定的系统任务。
进程的状态
①可运行状态:此时进程正在运行或者正在运行队列中等待准备运行。
②等待状态:此时进程在等待一个事件的发生或某种系统资源。在Linux系统中等待状态又细分为两种等待状态:可中断的等待状态和不可中断的等待状态。
③暂停状态:处于暂停状态的进程被暂停运行。
④僵死状态:每个进程在运行结束后都会处于僵死状态,等待父进程调用进而释放系统资源,处于该状态的进程已经运行结束,但是它的父进程还没有释放其系统资源。
ps [options] [—help]
ps [-aAcdefHjlmNVwy][acefghLnrsSTuvxX][-C <指令名称>][-g <群组名称>]
[-G <群组识别码>][-p <进程识别码>][p <进程识别码>][-s <阶段作业>]
[-t <终端机编号>][t <终端机编号>][-u <用户识别码>][-U <用户识别码>]
[U <用户名称>][-<进程识别码>][--cols <每列字符数>]
[--columns <每列字符数>][--cumulative][--deselect][--forest]
[--headers][--help][-- info][--lines <显示列数>][--no-headers]
[--group <群组名称>][-Group <群组识别码>][--pid <进程识别码>]
[--rows <显示列数>][--sid <阶段作业>][--tty <终端机编号>]
[--user <用户名称>][--User <用户识别码>][--version]
[--width <每列字符数>]
-a 显示所有终端机下执行的进程,除了阶段作业领导者之外
a 显示现行终端机下的所有进程,包括其他用户的进程
-A 显示所有进程
-c 显示CLS和PRI栏位
c 列出进程时,显示每个进程真正的指令名称,而不包含路径,参数或常驻服务的标示
-C<指令名称> 指定执行指令的名称,并列出该指令的进程的状况
-d 显示所有进程,但不包括阶段作业领导者的进程
-e 此参数的效果和指定"A"参数相同
e 列出进程时,显示每个进程所使用的环境变量
-f 显示UID,PPIP,C与STIME栏位
f 用ASCII字符显示树状结构,表达进程间的相互关系
-g<群组名称> 此参数的效果和指定"-G"参数相同,当亦能使用阶段作业领导者的名称来指定
g 显示现行终端机下的所有进程,包括群组领导者的进程
-G<群组识别码> 列出属于该群组的进程的状况,也可使用群组名称来指定
h 不显示标题列
-H 显示树状结构,表示进程间的相互关系
-j或j 采用工作控制的格式显示进程状况
-l或l 采用详细的格式来显示进程状况
L 列出栏位的相关信息
-m或m 显示所有的执行绪
n 以数字来表示USER和WCHAN栏位
-N 显示所有的进程,除了执行ps指令终端机下的进程之外
-p<进程识别码> 指定进程识别码,并列出该进程的状况
p<进程识别码> 此参数的效果和指定"-p"参数相同,只在列表格式方面稍有差异
r 只列出现行终端机正在执行中的进程
-s<阶段作业> 指定阶段作业的进程识别码,并列出隶属该阶段作业的进程的状况
s 采用进程信号的格式显示进程状况
S 列出进程时,包括已中断的子进程资料
-t<终端机编号> 指定终端机编号,并列出属于该终端机的进程的状况
t<终端机编号> 此参数的效果和指定"-t"参数相同,只在列表格式方面稍有差异
-T 显示现行终端机下的所有进程
-u<用户识别码> 此参数的效果和指定"-U"参数相同
u 以用户为主的格式来显示进程状况
-U<用户识别码> 列出属于该用户的进程的状况,也可使用用户名称来指定
U<用户名称> 列出属于该用户的进程的状况
v 采用虚拟内存的格式显示进程状况
-V或V 显示版本信息
-w或w 采用宽阔的格式来显示进程状况。
x 显示所有进程,不以终端机来区分
X 采用旧式的Linux i386登陆格式显示进程状况
-y 配合参数"-l"使用时,不显示F(flag)栏位,并以RSS栏位取代ADDR栏位
-<进程识别码> 此参数的效果和指定"p"参数相同
--cols<每列字符数> 设置每列的最大字符数
--columns<每列字符数> 此参数的效果和指定"--cols"参数相同
--cumulative 此参数的效果和指定"S"参数相同
--deselect 此参数的效果和指定"-N"参数相同
--forest 此参数的效果和指定"f"参数相同
--headers 重复显示标题列
--help 在线帮助
--info 显示排错信息
--lines<显示列数>设置显示画面的列数
--no-headers 此参数的效果和指定"h"参数相同,只在列表格式方面稍有差异
--group<群组名称> 此参数的效果和指定"-G"参数相同
--Group<群组识别码> 此参数的效果和指定"-G"参数相同
--pid<进程识别码> 此参数的效果和指定"-p"参数相同
--rows<显示列数> 此参数的效果和指定"--lines"参数相同
--sid<阶段作业> 此参数的效果和指定"-s"参数相同
--tty<终端机编号> 此参数的效果和指定"-t"参数相同
--user<用户名称> 此参数的效果和指定"-U"参数相同
--User<用户识别码> 此参数的效果和指定"-U"参数相同
--version 此参数的效果和指定"-V"参数相同
--widty<每列字符数> 此参数的效果和指定"-cols"参数相同
-A 列出所有的行程
-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程
linux上进程有5种状态:
1. 运行(正在运行或在运行队列中等待)
2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)
3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行)
ps工具标识进程的5种状态码:
D 不可中断 uninterruptible sleep (usually IO)
R 运行 runnable (on run queue)
S 中断 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process
1、# ps aux //显示所有正在内存中的程序
USER:该 process 属于那个使用者账号的
PID :该 process 的号码
%CPU:该 process 使用掉的 CPU 资源百分比
%MEM:该 process 所占用的物理内存百分比
VSZ :该 process 使用掉的虚拟内存量 (Kbytes)
RSS :该 process 占用的固定的内存量 (Kbytes)
TTY :该 process 是在那个终端机上面运作,若与终端机无关,则显示 ?,另外, tty1-tty6 是本机上面的登入者程序,若为 pts/0 等等的,则表示为由网络连接进主机的程序。
STAT:该程序目前的状态,主要的状态有
R :该程序目前正在运作,或者是可被运作
S :该程序目前正在睡眠当中 (可说是 idle 状态),但可被某些讯号 (signal) 唤醒。
D: 无法中断的休眠状态 (通常 IO 的进程)
T :该程序目前正在侦测或者是停止了
Z :该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
<: 高优先序的行程
N: 低优先序的行程
L: 有记忆体分页分配并锁在记忆体内 (实时系统或捱A I/O)
START:该 process 被触发启动的时间
TIME :该 process 实际使用 CPU 运作的时间
COMMAND:该程序的实际指令
2、# ps -A 显示进程信息
3、# ps -u work //显示work进程用户信息
4、# ps -ef //显示所有命令,连带命令行
5、# ps -l //将属于自己这次登入的pid与相关信息显示出来
F:代表这个程序的旗标 (flag), 4 代表使用者为 super user
S:代表这个程序的状态 (STAT)
UID:程序被该 UID 所拥有
PID:就这个程序的 ID
PPID:其上级父程序的ID
C:CPU使用的资源百分比
PRI: Priority (优先执行序) 的缩写
NI: Nice 值
ADDR:kernel function,指出该程序在内存的那个部分。如果是个 running的程序,一般就是 "-"
SZ:使用掉的内存大小
WCHAN:目前这个程序是否正在运作当中,若为 - 表示正在运作
TTY:登入者的终端机位置
TIME:使用掉的 CPU 时间。
CMD:所下达的指令为何
在预设的情况下, ps 仅会列出与目前所在的 bash shell 有关的 PID,所以, 当使用 ps -l 的时候,只有三个 PID。
6、其他
1)可以用 | 管道和 more 连接起来分页查看
命令:ps -aux |more
2)把所有进程显示出来,并输出到ps001.txt文件
命令:ps -aux > ps001.txt
3)输出指定的字段
命令:ps -o pid,ppid,pgrp,session,tpgid,comm
只有在该状态的进程才可能在CPU上运行。同一时刻可能有多个进程处于可执行状态,这些进程的task_struct结构(进程控制块)被放入对应CPU的可执行队列中(一个进程最多只能出现在一个CPU的可执行队列中)。进程调度器从各个CPU的可执行队列中分别选择一个进程在该CPU上运行。正在CPU上执行的进程定义为RUNNING状态、可执行但尚未被调度执行的进程定义为READY状态,这两种状态统一为 TASK_RUNNING状态。S (TASK_INTERRUPTIBLE),可中断的睡眠状态。处于这个状态的进程,因为等待某某事件的发生(比如等待socket连接、等待信号量),而被挂起。这些进程的task_struct结构被放入对应事件的等待队列中。当这些事件发生时(由外部中断触发、或由其他进程触发),对应的等待队列中的一个或多个进程将被唤醒。进程列表中的绝大多数进程都处于TASK_INTERRUPTIBLE状态。CPU就这么一两个,进程动辄几十上百个,如果不是绝大多数进程都在睡眠,CPU将会响应不过来。D (TASK_UNINTERRUPTIBLE),不可中断的睡眠状态。进程处于睡眠状态,但是此刻进程是不可中断的。不可中断,指的并不是CPU不响应外部硬件的中断,而是指进程不响应异步信号。绝大多数情况下,进程处在睡眠状态时,总是应该能够响应异步信号的。而TASK_UNINTERRUPTIBLE状态存在的意义在于,进程对某些硬件进行 *** 作时(比如进程调用read系统调用对某个设备文件进行读 *** 作,而read系统调用最终执行到对应设备驱动的代码,并与对应的物理设备进行交互),可能需要使用TASK_UNINTERRUPTIBLE状态对进程进行保护,以避免进程与设备交互的过程被打断,造成设备陷入不可控的状态。这种情况下的TASK_UNINTERRUPTIBLE状态总是非常短暂的,通过ps命令基本上不可能捕捉到。 linux系统中也存在容易捕捉的TASK_UNINTERRUPTIBLE状态。执行vfork系统调用后,父进程将进入TASK_UNINTERRUPTIBLE状态,直到子进程调用exit或exec。通过下面的代码就能得到处于TASK_UNINTERRUPTIBLE状态的进程:#include <stdio.h>#include <unistd.h>void main(){if (!vfork())sleep(100)ruturn 0} 编译运行,然后ps一下:njs@njs:~/test$ ps -ax | grep a\.out4371 pts/0 D+ 0:00 ./a.out4372 pts/0 S+ 0:00 ./a.out4374 pts/1 S+ 0:00 grep a.out欢迎分享,转载请注明来源:内存溢出
评论列表(0条)