ps与top命令简单介绍

Linux中ps与top命令

这两个命令都是查看系统进程信息的命令,但是用处有点儿不同

1.ps命令--提供系统过去信息的一次性快照

也就是说ps命令能够查看刚刚系统的进程信息  命令:ps aux或者ps lax

[[email protected] ~]# ps aux
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.1  0.1   2032   644 ?        Ss   21:55   0:01 init [3]
root         2  0.0  0.0      0     0 ?        S    21:55   0:00 [migration/0]
root         3  0.0  0.0      0     0 ?        SN   21:55   0:00 [ksoftirqd/0]

......

解释如下:

VSZ--进程的虚拟大小

RSS--驻留集的大小,可以理解为内存中页的数量

TTY--控制终端的ID

STAT--也就是当前进程的状态,其中S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通优先级更低的优先级,R-正在运行,D-短期等待,Z-僵死进程,T-被跟踪或者被停止等等

STRAT--这个很简单,就是该进程启动的时间

TIME--进程已经消耗的CPU时间,注意是消耗CPU的时间

COMMOND--命令的名称和参数

而]#ps lax  可以看到父进程,谦让值以及该进程正在等待的资源等待

2.top命令--这个命令就很有用了

top命令反应的是系统进程动态信息,默认10s更新一次

[[email protected] ~]#top

top - 22:30:58 up 35 min,  1 user,  load average: 0.12, 0.07, 0.08
Tasks:  72 total,   1 running,  71 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.2%us,  0.2%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:    373320k total,    88600k used,   284720k free,     9956k buffers
Swap:   514072k total,        0k used,   514072k free,    45092k cached

PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
 3217 root      15   0  2160  976  788 R    1  0.3   0:00.07 top
    1 root      15   0  2032  644  552 S    0  0.2   0:01.55 init
    2 root      RT   0     0    0    0 S    0  0.0   0:00.02 migration/0
    3 root      34  19     0    0    0 S    0  0.0   0:00.00 ksoftirqd/0
    4 root      RT   0     0    0    0 S    0  0.0   0:00.00 watchdog/0
    5 root      RT   0     0    0    0 S    0  0.0   0:00.02 migration/1
    6 root      39  19     0    0    0 S    0  0.0   0:00.00 ksoftirqd/1
    7 root      RT   0     0    0    0 S    0  0.0   0:00.00 watchdog/1

......

以上就是top命令的部分输出,可以看到该命令显示了较为详细的信息

顶部始终显示的是系统当前最活跃的进程,此时还可以接受用户的键盘输入向进程发送信号等待

3.ps和top都是从/proc目录下读取进程的状态信息,内核把当前系统进程的各种有用信息都放在这个伪目录下。

转自:http://blog.chinaunix.net/uid-22858177-id-381533.html

=========================================================================

一:ps

ps -l

查看属于自己这次登录的PID与相关信息列出来(只与自己的bash有关)

F:代表这个进程标志(process flags),说明这个进程的权限,常见号码有:

若为4表示此进程的权限为root;

若为1则表示此子进程仅可进行复制(fork)而无法执行(exec);

S:代表这个进程的状态(STAT),主要的状态有:

R(Running):该进程正在运行中;

S(Sleep):该进程目前正在睡眠状态(idle),但可以被唤醒(signal);

D:不可被唤醒的状态,通常这个进程可能在等待I/O的情况(ex>打印);

T:停止状态(stop),可能是在工作控制(后台暂停)或出错(traced)状态;

Z(Zombie):“僵尸”状态,该进程已经终止但却无法被删除至内存外。

UID/PID/PPID:代表此进程被该UID所拥有的/进程的PID号码/此进程的父进程PID号码。

C:代表CPU使用率,单位为百分比。

PRI/NI:Priority/Nice的缩写,代表此进程被CPU所执行的优先级,数值越小代表此进程越快被CPU执行。

ADDR/SZ/WCHAN:都与内存有关,ADDR是kernel function,指出该进程在内存的哪个部分,如果是个running的进程,一般会显示“—”。SZ代表此进程用掉多少内存。WCHAN表示目前进程是否在运行中,同样,若为“—”表示正在运行中。

TTY:登录者的终端位置,若为远程登录使用动态终端接口(pts/n)。

TIME:使用CPU的时间,注意,是此进程实际花费CPU运行的时间,而不是系统时间。

CMD:就是command的缩写,造成此程序的触发进程的命令为何。

ps aux

查看系统所有进程数据(静态) USER:该进程属于哪个用户账号的;

PID:该进程的进程标识符;

%CPU:该进程使用掉的CPU资源百分比;

%MEM:该进程所占用的物理内存百分比;

VSZ:该进程所占用的虚拟内存量(KB);

RSS:该进程所占用的固定的内存量(KB);

TTY:该进程在哪个终端机上面运行,若与终端机无关则显示?另外,tty1~tty6是本机上面的登录者程序,若为pts/0等的,则表示为由网络连接进主机的进程; STAT:该进程目前的状态,状态显示与ps -l的S标识相同(R/S/T/Z);

TIME:该进程实际使用CPU的时间;

COMMAND:该进程的实际命令。

二:top (动态)

统计信息区前五行是系统整体的统计信息。

第一行是任务队列信息,同 uptime 命令的执行结果。其内容如下:

02:44:02                      当前时间

up 21 days  ,2:12          开机到目前为止所经过的时间

3 users                          当前登录用户数

0.56, 0.23, 0.32            系统负载,即任务队列的平均长度。三个数值分别为1分钟、5分钟、15分钟前到现在的平均值。

第二行为进程信息,内容如下:

Tasks:  113 total       进程总数

1 running                正在运行的进程数

112sleeping             睡眠的进程数

0 stopped               停止的进程数

0 zombie                 僵尸进程数

第三行为CPU信息,当有多个CPU时,这些内容可能会超过两行。内容如下:

Cpu(s):

0.0%us                      用户空间占用CPU百分比

0.0% sy                     内核空间占用CPU百分比

0.0% ni                      用户进程空间内改变过优先级的进程占用CPU百分比

0.0% id                      空闲CPU百分比

0.0% wa                     等待输入输出(IO)的CPU时间百分比

0.0% hi                      cpu处理硬件中断的时间;

0.0% si                      cpu处理软中断的时间;

第四行为内存信息,内容如下:

Mem: 1034872k total          物理内存总量

974264k used                    使用的物理内存总量

60608k free                       空闲内存总量

226140k buffers                 用作内核缓存的内存量

第五行为SWAP信息

Swap: 1534072k total        交换区总量

0used                               使用的虚拟内存总量

1534072k free                   空闲交换区总量

548268k cached                 缓冲的交换区总量。

第六行往后是进程列表,常见的这几列的意义分别为:

PID(进程号), USER(运行用户),PR(优先级),NI(任务nice值),VIRT(虚拟内存用量),RES(物理内存用量), SHR(共享内存用量),S(进程状态),%CPU(CPU占用比),%MEM(内存占用比),TIME+(累计CPU占用时间)。

除了这些信息之外,top还提供了很多命令能帮我们更好的解读这些信息,例如按”M”键可以按内存用量进行排序;

按”P”可以按CPU使用量进行排序,这样一来对于分析系统瓶颈很有帮助;此外,

按“f”可以进入交互页面,选择指定的列显示;

”r”可以改变一个进程的nice值;”k”可以向一个进程发信号;

”z”可以使用彩色显示。进程信息区统计信息区域的下方显示了各个进程的详细信息。

首先来认识一下各列的含义。

序号    列名    含义

a    PID       进程id

b    PPID      父进程id

c    RUSER     Real user name

d    UID       进程所有者的用户id

e    USER      进程所有者的用户名

f    GROUP     进程所有者的组名

g    TTY       启动进程的终端名。不是从终端启动的进程则显示为 ?

h    PR        优先级

i    NI        nice值。负值表示高优先级,正值表示低优先级

j    P         最后使用的CPU,仅在多CPU环境下有意义

k    %CPU     上次更新到现在的CPU时间占用百分比

l    TIME     进程使用的CPU时间总计,单位秒

m    TIME+    进程使用的CPU时间总计,单位1/100秒

n    %MEM     进程使用的物理内存百分比

o    VIRT     进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

p    SWAP     进程使用的虚拟内存中,被换出的大小,单位kb。

q    RES      进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA

r    CODE     可执行代码占用的物理内存大小,单位kb

s    DATA     可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb

t    SHR      共享内存大小,单位kb

u    nFLT     页面错误次数

v    nDRT     最后一次写入到现在,被修改过的页面数。

w    S        进程状态。

x    COMMAND  命令名/命令行

y    WCHAN    若该进程在睡眠,则显示睡眠中的系统函数名

z    Flags    任务标志,参考 sched.h

D=不可中断的睡眠状态

R=运行

S=睡眠

T=跟踪/停止

Z=僵尸进程

默认情况下仅显示比较重要的  PID、USER、PR、NI、VIRT、RES、SHR、S、%  CPU、%MEM、TIME+、COMMAND  列。可以通过下面的快捷键来更改显示内容。

更改显示内容通过 f 键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z  即可显示或隐藏对应的列,最后按回车键确定。

时间: 2024-10-21 06:29:25

ps与top命令简单介绍的相关文章

LINUX之ps,pstree,top,vmstat简单介绍

ps,pstree,top,vmstat用来查看进程或系统负载.下面介绍经常使用的命令组合,或显示内容解释. 程序,进程,线程的关系 程序:拥有某此功能(能被cpu运行的指令),可以被cpu调用运行的文件,通常都放在外部存储设备上. 进程:程序文件被调用运行时,一般都在内存中或cpu正在执行的程序. 线程:把进程中的执行任务的指令分成多个片,而每片可以单独做为一个执行流运行和调用,并且每个片可以分配到不同的cpu核心上运行.可以被单独调用的片称为线程.线程是比进程更小的调度单位.比进程更轻量级.

linux常用命令简单介绍(netstat,awk,top,tail,head,less,more,cat,nl)

1.netstat netstat -tnl | grep 443 (查看443端口是否被占用) root用户,用netstat -pnl | grep 443 (还可显示出占用本机443端口的进程PID). -a (all)显示所有选项,默认不显示LISTEN相关 -t (tcp)仅显示tcp相关选项 -u (udp)仅显示udp相关选项 -n 拒绝显示别名,能显示数字的全部转化成数字.直接使用IP地址,而不通过域名服务器. -l 仅列出有在 Listen (监听) 的服務状态 -p 显示建立

Linux_常用命令简单介绍(netstat,awk,top,tail,head,less,more,cat,nl)

1.netstat netstat -tnl | grep 443 (查看443端口是否被占用) root用户,用netstat -pnl | grep 443 (还可显示出占用本机443端口的进程PID). -a (all)显示所有选项,默认不显示LISTEN相关 -t (tcp)仅显示tcp相关选项 -u (udp)仅显示udp相关选项 -n 拒绝显示别名,能显示数字的全部转化成数字.直接使用IP地址,而不通过域名服务器. -l 仅列出有在 Listen (监听) 的服務状态 -p 显示建立

Git flow的分支模型与及经常使用命令简单介绍

Git flow是git的一个扩展集,它基于Vincent Driessen 的分支模型,文章"A successful Git branching model"对这一分支模型进行了描写叙述.其示意图例如以下: 上图从左往右看,分别为 - 时间轴.从上往下时间在流逝 - feature分支(玫红).图上有两个feature分支,在这个分支上,进行功能特性的开发 - develop分支(黄色).git flow的主分支.feature分支和release分支都会将代码合并到此分支上 -

Linux 查看进程资源--ps、top命令

1,ps命令 ps能够给出当前系统中进程的快照.它能捕获系统在某一事件的进程状态 命令参数:         a                                      显示所有进程        -a                                      显示同一终端下的所有程序        -A                                     显示所有进程         c                           

shutdown reboot init   重启命令 关机命令 简单介绍

Linux centos重启命令: 1.reboot 2.shutdown -r now 立刻重启(root用户使用) 3.shutdown -r 10 过10分钟自动重启(root用户使用) 4.shutdown -r 20:35 在时间为20:35时候重启(root用户使用) 如果是通过shutdown命令设置重启的话,可以用shutdown -c命令取消重启 Linux centos关机命令: 1.halt 立刻关机 2.poweroff 立刻关机 3.shutdown -h now 立刻

RHEL7 CentOS7 的 firewall命令简单介绍

firewall 服务介绍 firewall 服务是 redhat7 和 centos7 系统默认安装好的防火墙服务,一个信任级别的概念来管理与之相关联的连接与接口.它支持 ipv4 与 ipv6,并支持网桥,采用 firewall-cmd (command) 或 firewall-config (gui) 来动态的管理 kernel netfilter 的临时或永久的接口规则,并实时生效而无需重启服务. Firewall 能将不同的网络连接归类到不同的信任级别,Zone 提供了以下几个级别:

Linux的bg和fg命令简单介绍

我们都知道,在 Windows 上面,我们要么让一个程序作为服务在后台一直运行,要么停止这个服务.而不能让程序在前台后台之间切换.而 Linux 提供了 fg 和 bg 命令,让我们轻松调度正在运行的任务.假设你发现前台运行的一个程序需要很长的时间,但是需要干其他的事情,你就可以用 Ctrl-Z ,挂起这个程序,然后可以看到系统提示(方括号中的是作业号): 复制代码 代码如下: [1]+ Stopped /root/bin/rsync.sh 然后我们可以把程序调度到后台执行:(bg 后面的数字为

linux ps top 命令 VSZ,RSS,TTY,STAT, VIRT,RES,SHR,DATA的含义

linux ps top 命令 VSZ,RSS,TTY,STAT, VIRT,RES,SHR,DATA的含义 linuxpstop http://javawind.net/p131 VIRT:virtual memory usage 虚拟内存 1.进程“需要的”虚拟内存大小,包括进程使用的库.代码.数据等 2.假如进程申请100m的内存,但实际只使用了10m,那么它会增长100m,而不是实际的使用量 RES:resident memory usage 常驻内存 1.进程当前使用的内存大小,但不包