求宠夫日常by渣尽千帆by北叶枫txt火的百度云或者微盘资源,实在不行有可以看防盗章的

linux 下如何查看某个进程内存的使用量? - ITeye问答
linux 下如何查看某个进程内存的使用量?
在Linux下用ps或者top可以查看每个进程占用内存情况。
但是它们显示的时候都完全包含共享库所占用的内存。例如进程1和2都使用一个共享库 3,3占用内存1m,那么在ps中,进程1占用的内存完全包含这1m,进程2也一样。在exmap这个工具中,它可以识别某个共享库被多少进程使用,因此 将所占用的内存平摊在各进程的内存使用量中。在上例中,1和2各用500k
除共享库外,它还可以识别某个文件由多少进程在打开以及在各个进程中的内存占用情况。
该程序依赖于exmap.ko该模块,使用时用insmod加载即可
可以用top命令试试
/javava/blog/item/343d28db4ee0.html
应该没法做到,因为很多的library(.so)是多进程共享的。
已解决问题
未解决问题linux下查询进程占用的内存方法总结 - 推酷
linux下查询进程占用的内存方法总结
linux下查询进程占用的内存方法总结
假设现在有一个「php-cgi」的进程 ,进程id为「25282」。现在想要查询该进程占用的内存大小。linux命令行下有很多的工具进行查看,现总结常见的几种方式:
通过进程的 status
[root@web3_u ~]# cat /proc/25282/status
S (sleeping)
TracerPid:
ffffffffffffffff
Cpus_allowed:
Cpus_allowed_list:
Mems_allowed:
00,00,00,00,00,
Mems_allowed_list:
voluntary_ctxt_switches:
nonvoluntary_ctxt_switches:
VmRSS: 113612 kB 表示占用的物理内存
[root@web3_u ~]# pmap -x 25282
/usr/local/php/bin/php-cgi --fpm --fpm-config /usr/local/php/etc/php-fpm.conf
Dirty Mode
ld-2.12.so
00007fff84b02000
00007fff84bff000
ffffffffff600000
----------------
关键信息点
启动命令「/usr/local/php/bin/php-cgi --fpm --fpm-config /usr/local/php/etc/php-fpm.conf」
RSS :占用的物理内存 113612KB
通过 smaps
[root@web3_u ~]# cat /proc/25282/smaps | grep '^Rss:' \
| awk '{sum +=$2} END{print sum}'
求和得到实际占用物理内存为 113612
通过 ps 命令
[root@web3_u ~]#
ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid'
| awk '$1 ~ /25282/'
25282 php-cgi
/usr/local/php/bin/php-cgi
0.0 284 Oct09 nobody
awk 过滤 25282 进程号,得到第5列「rsz」的内存大小为「113612」
输出php-cgi进程占用的物理内存,并从高到低进行排序
[root@web3_u ~]# ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid'
| grep php-cgi | sort -k5nr
23946 php-cgi
/usr/local/php/bin/php-cgi
0.0 000 Oct06 nobody
24418 php-cgi
/usr/local/php/bin/php-cgi
0.0 684 Oct06 nobody
18973 php-cgi
/usr/local/php/bin/php-cgi
0.0 176 Oct06 nobody
17219 php-cgi
/usr/local/php/bin/php-cgi
0.0 840 Oct06 nobody
6996 php-cgi
/usr/local/php/bin/php-cgi
0.0 104 Oct09 nobody
23850 php-cgi
/usr/local/php/bin/php-cgi
0.0 036 Oct09 nobody
28310 php-cgi
/usr/local/php/bin/php-cgi
0.0 456 Oct09 nobody
其中rsz为实际内存,上例实现按内存排序,由大到小
TOP 命令输出的列
SHR S %CPU %MEM
25282 nobody
0:34.42 php-cgi
输出列信息
用户 nobody
虚拟内存 428M
物理内存 110M 110* 「和前面计算出来的值基本一致」
共享内存 93M
进程使用的物理内存和总内存的百分比 1.9 %
PID:进程的ID
USER:进程所有者
PR:进程的优先级别,越小越优先被执行
NInice:值
VIRT:进程占用的虚拟内存
RES:进程占用的物理内存
SHR:进程使用的共享内存
S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数
%CPU:进程占用CPU的使用率
%MEM:进程使用的物理内存和总内存的百分比
TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。
COMMAND:进程启动命令名称
SHR S %CPU %MEM
16036 root
480 R 100.0 36.6
0:33.15 redis-server
12934 root
0 g 1072 S
5.5 36.6 285:37.81 redis-server
0.0 277:14.85 flush-252:16
50m 3264 S
1445:03 xs-searchd
0.0 635:05.31 xs-indexd
1287 nobody
0.0 833:11.42 dnsmasq
39m 3244 S
1437:57 xs-searchd
27:43.92 nginx
0:06.75 init
按 P .表示按cpu排序,默认也是按cpu排序
SHR S %CPU %MEM
12934 root
0 g 1072 S
6.0 36.6 285:39.77 redis-server
16036 root
480 R 100.0 36.6
1:11.42 redis-server
0 m 6556 S
4:40.70 php-cgi
0 m 6536 S
4:20.82 php-cgi
0 m 6584 S
4:21.85 php-cgi
按M 。 表示按占用内存排序。 第一列 redis服务器占用了8.6G的内存 。 这个内存和redis info
[root@img1_u ~]# redis-cli info memory
used_memory_human:8.32G
基本相同。
[root@img1_u ~]# top -u www
top - 22:09:01 up 67 days, 14:16,
load average: 0.61, 0.90, 0.98
Tasks: 283 total,
2 running, 281 sleeping,
0 stopped,
0.5%ni, 89.7%id,
k total, k used,
3412116k free,
1750652k buffers
524280k total,
524280k free,
4039732k cached
SHR S %CPU %MEM
25m 5796 S
0:47.00 php-cgi
57m 6484 S
4:41.66 php-cgi
34m 6320 S
3:52.39 php-cgi
0 m 6584 S
4:21.85 php-cgi
39m 6376 S
3:57.84 php-cgi
56m 6244 S
3:44.75 php-cgi
66m 6480 S
4:16.12 php-cgi
60m 6288 S
4:13.35 php-cgi
62m 6408 S
4:06.60 php-cgi
-u 指定用户。 php-cgi占用的内存在60M左右
按进程消耗内存多少排序的方法
通过 ps 命令
第一种方法
ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' | sort -k5nr
第二种方法
ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' --sort -rsz
[root@web3_u ~]# ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user' | sort -k5nr
23946 php-cgi
/usr/local/php/bin/php-cgi
0.0 000 Oct06 nobody
24418 php-cgi
/usr/local/php/bin/php-cgi
0.0 684 Oct06 nobody
18973 php-cgi
/usr/local/php/bin/php-cgi
0.0 176 Oct06 nobody
17219 php-cgi
/usr/local/php/bin/php-cgi
0.0 840 Oct06 nobody
6996 php-cgi
/usr/local/php/bin/php-cgi
0.0 104 Oct09 nobody
23850 php-cgi
/usr/local/php/bin/php-cgi
0.0 036 Oct09 nobody
-e 显示所有进程
-o 定制显示信息
pid 进程ID
comm 进程名
args 启动命令
pcpu 占用CPU 百分比
rsz 占用物理内存大小
vsz 占用虚拟内存大小
stime 进程启动时间
user 启动用户
以第一行为例
进程ID 23946
进程名 php-cgi
启动命令 /usr/local/php/bin/php-cgi
占用物理内存 129540
占用虚拟内存 440000
启动时间 Oct06
启动用户 nobody
通过 top 命令
top命令默认是以CPU排序输出的,按字母「M」,可以按内存占用大小进行排序显示
SHR S %CPU %MEM
23946 nobody
429m 126m 107m S
1:15.01 php-cgi
24418 nobody
427m 126m 109m S
1:19.56 php-cgi
18973 nobody
429m 126m 107m S
1:20.18 php-cgi
17219 nobody
429m 123m 104m S
1:23.60 php-cgi
6996 nobody
427m 122m 105m S
1:05.27 php-cgi
23850 nobody
429m 120m 101m S
1:02.43 php-cgi
输出参数介绍
PID:进程的ID
USER:进程所有者
VIRT:进程占用的虚拟内存
RES:进程占用的物理内存
SHR:进程使用的共享内存
S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数
%CPU:进程占用CPU的使用率
%MEM:进程使用的物理内存和总内存的百分比
TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。
通过比较进程ID 「23946」,top 命令和 ps 命令输出的结果基本保持一致
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致Linux系统中查看执行中的进程占用内存量的方法
作者:胡桃夹子
字体:[ ] 来源:hutaow 时间:07-07 12:06:23
我们可以使用cat命令查看Linux中的内存占用情况,这里就以cat的各个参数用法为主讲解Linux系统中查看执行中的进程占用内存量的方法,需要的朋友可以参考下
Linux中查看某个进程占用内存的情况,执行如下命令即可,将其中的[pid]替换成相应进程的PID号:代码如下:cat /proc/[pid]/status
说明/proc/[pid]/status中所保存的信息除了内存信息,还包括进程IDs、信号等信息,此处暂时只介绍内存相关的信息。
进程所使用的虚拟内存的峰值
进程当前使用的虚拟内存的大小
已经锁住的物理内存的大小(锁住的物理内存不能交换到硬盘)
进程所使用的物理内存的峰值
进程当前使用的物理内存的大小
进程占用的数据段大小
进程占用的栈大小
进程占用的代码段大小(不包括库)
进程所加载的动态库所占用的内存大小(可能与其它进程共享)
进程占用的页表大小(交换表项数量)
进程所使用的交换区的大小
举例显示进程cron的内存信息,通过pidof cron获取进程ID,或者通过ps -aux | grep cron查找进程ID。代码如下:$ cat /proc/1161/statusName:&& cronState:& S (sleeping)Tgid:&& 1161Ngid:&& 0Pid:&&& 1161PPid:&& 1TracerPid:& 0Uid:&&& 0&& 0&& 0&& 0Gid:&&& 0&& 0&& 0&& 0FDSize: 64Groups: 0 VmPeak:&&& 23792 kBVmSize:&&& 23656 kBVmLck:&&&&&&&& 0 kBVmPin:&&&&&&&& 0 kBVmHWM:&&&&& 1040 kBVmRSS:&&&&& 1004 kBVmData:&&&&& 260 kBVmStk:&&&&&& 136 kBVmExe:&&&&&&& 40 kBVmLib:&&&&& 2668 kBVmPTE:&&&&&&& 72 kBVmSwap:&&&&&&& 0 kBThreads:&&& 1SigQ:&& 0/15442SigPnd: 0000ShdPnd: 0000SigBlk: 0000SigIgn: 0000SigCgt: 0001CapInh: 0000CapPrm: 0000001fffffffffCapEff: 0000001fffffffffCapBnd: 0000001fffffffffSeccomp:&&& 0Cpus_allowed:&& 3Cpus_allowed_list:& 0-1Mems_allowed:&& 00001Mems_allowed_list:& 0voluntary_ctxt_switches:&&& 151nonvoluntary_ctxt_switches: 0
大家感兴趣的内容
12345678910
最近更新的内容3910人阅读
linux调试技巧(20)
1. 在linux下,查看一个运行中的程序, 占用了多少内存, 一般的命令有
&& (1). ps aux:
&& & 其中 &VSZ(或VSS)列 表示,程序占用了多少虚拟内存。
&& & & & & RSS列 表示, 程序占用了多少物理内存。
&& & & & & 虚拟内存可以不用考虑,它并不占用实际物理内存。
&& (2). top 命令也可以
&& & 其中 &VIRT(或VSS)列 &表示,程序占用了多少虚拟内存。 同 ps aux 中的 VSZ列
&& & & & & RES列&表示, 程序占用了多少物理内存。同 ps aux 中的RSS列
&& & & & &&
2.在linux下, 查看当前系统占用了多少内存, 一般的命令是 &free
其中, free就是系统还有多少内存可以使用。
但由于 linux 系统对内存使用有一个原则, 就是, 内存是宝贵的, 能使用多少就使用多少。 所以, linux会把已经调用过的包缓存起来,放在内存里。
这样,实际上,可以使用的内存,就可以理解为, free+buffers+cached
3.当你了解完这些命令以后, 再去使用ps aux 命令去查看的时候, 会发现一个奇怪的现象。
&所有的 &RSS 列的数据,加起来, 比物理内存的数要大很多。
&比如, 物理内存为2G, 而RSS列的数据加起来,可能有5个G之多, 这是怎么回事了?
&这是因为RSS列的值骗了我们。&
&linux的内存机制是这样的:
&在运行一个程序时, linux会调用该程序依赖的链接库, 如lib.xx.so。&首先看该链接库是否被映射进内存中,如果没有被映射,则将代码段与数据段映射到内存中,否则只是将其加入进程的地址空间。
&这样,当N个程序,依赖到lib.xx.so的时候, 实际上,内存中只有一个lib.xx.so ,而不是N个。&
&而RSS在显示一个程序占用的实际物理内存时, 将lib.xx.so也算了进来。
&比如, X程序, 本身占用内存为5M, lib.xx.so 占用内存2M,lib.xx.so被N个程序共享依赖。 则RSS显示为,X程序运行,占用内存为7M。 实际上, X程序占用了5M空间。 多余的2m被讨入到RSS中了。
&当你在用ps aux显示内存占用情况时, N个共享依赖lib.xx.so的N个程序,都把这2m空间,算在自己的RSS中了, 这样RSS的sum值,就比实际物理内存多了。
&当然, linux的内存使用机制很复杂, 不是一句两句能说清楚的。这里只是简单的说明了一下, ps aux中的RSS值, 并不能真实反映物理内存的使用情况。
4. 如果查看更详细的内存使用情况, 可用以下几种方法, 或者几种方法结合使用:
这几种方法,都需要root账户的权限
(1).&pmap -d $pid&
$pid 是正在运行的程序的pid
(2). cat /proc/$pid/smaps
&&smaps的数据比较详细,可简单的归纳一下,归纳的命令如下:
&&cat /proc/$pid/smaps&&| awk '/Size|Rss|Pss|Shared|Private|Referenced|Swap/{val_name=gensub(/([a-zA-Z_]*).*/,&\\1&,1,$1); list[val_name]+=$2; }END{for(val in list)print val,list[val];}' & & & & & & & & & &&
(3). cat /proc/$pid/maps
(4). cat /proc/$pid/statm
第一列 &size:任务虚拟地址空间大小
第二列 &Resident:正在使用的物理内存大小
第三列 &Shared:共享页数
第四列 &Trs:程序所拥有的可执行虚拟内存大小
第五列 &Lrs:被映像倒任务的虚拟内存空间的库的大小
第六列 &Drs:程序数据段和用户态的栈的大小
第七列 dt:脏页数量
(5).&vmstat
这个命令据说也可以提供一些参考信息,具体还未研究
5.作为phper,尝试过使用php的函数memory_get_usage(), 该函数也不能得到php当前运行的程序,实际的,真正占用的内存数量。
&&如果真想得到,php真正占用的内存, 大概只能在, 程序运行的开始,执行一次memory_get_usage().
&&在程序运行结束,执行一次memory_get_usage()。 将两者的值相减,得到的值, 应该是一个相对比较准确的,内存占用数量了。
&&这个方法还没有测试, 考虑到, 得到这个数量,也没有实际意义, 加上平时又比较忙,懒得试了。
&&也许php还有一个方法, 是使用shm_* 系列函数, 这也我也未深入研究,详见这篇文章()
&6.另外还有一些文章可以参考,如下:
&(1)一个C程序员, 眼中的,写的比较详细,比较细致,也比较专业。
&(6),这篇文章似乎是对一个产品的广告,但里面对USS,PSS,RSS 这几个概念有详细的解释
&(7)&,跟(6)一样,是对同一个产品的广告,文章里有一些东西可以参考
(8)&,文章对 free, vmstat,top ,&gnome-system-monitor等命令有一些介绍
(9),对top,free,uptime,pmap,smartctl,iostat,strace等命令有所介绍,并且介绍的比较详细,目前只是粗略的看了一下,有时间还要再看看。&
(10),比较详细的介绍了pmap的应用,不过是基于Solaris 9的
显示其他用户启动的进程(a)
查看系统中属于自己的进程(x)
启动这个进程的用户和它启动的时间(u)
使用“date -s”命令来修改系统时间
比如将系统时间设定成日的命令如下。
#date -s 06/10/96
将系统时间设定成下午1点12分0秒的命令如下。
#date -s 13:12:00
------------------------------------------------------
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.0
? S Nov05 0:04 init
root 2 0.0 0.0 0 0 ? SW Nov05 0:00 [keventd]
root 3 0.0 0.0 0 0 ? SW Nov05 0:00 [keventd]
------------------------------------------------------
USER域指明了是哪个用户启动了这个命令;
用户可以查看某个进程占用了多少CPU;
内存使用及其VSZ(虚拟内存大小)和RSS(常驻集大小):
VSZ表示如果一个程序完全驻留在内存的话需要占用多少内存空间;
RSS指明了当前实际占用了多少内存;
STAT显示了进程当前的状态:
&S&:进程处在睡眠状态,表明这些进程在等待某些事件发生--可能是用户输入或者系统资源的可用性;
last命令可以有效的查看系统登录事件
在一个进程调用了exit之后,该进程并非马上就消失掉,而是留下一个称为僵尸进程(Zombie)的数据结构。在Linux进程的5种状态中,僵尸进程是非常特殊的一种,它已经放弃了几乎所有内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集,除此之外,僵尸进程不再占有任何内存空间。
系统调用exit的作用是使进程退出,但也仅仅限于将一个正常的进程变成一个僵尸进程,并不能将其完全销毁。
进程一旦调用了wait,就立即阻塞自己,由wait自动分析是否当前进程的某个子进程已经退出,如果让它找到了这样一个已经变成僵尸的子进程,wait 就会收集这个子进程的信息,并把它彻底销毁后返回;如果没有找到这样一个子进程,wait就会一直阻塞在这里,直到有一个出现为止。
转载 &ps aux 中STAT 解释 收藏
运行 ps aux 的到如下信息:
USER & &PID & %CPU %MEM VSZ & RSS TTY & &STAT & START TIME COMMAND
smmsp 3521 & 0.0 & &0.7 & &
& & ? & & & &Ss & & &20:40 0:00 sendmail: Queue runner@01:00:00 f
root & &3532 & &0.0 & & & 0.2 & & 2428 & &452 & & ? & & & &Ss & & &20:40 0:00 gpm -m /dev/input/mice -t imps2
htt & & & &3563 & &0.0 & & & 0.0 & &2956 & &196 & & ? & & & &Ss & & & 20:41 0:00 /usr/sbin/htt -retryonerror 0
htt & & & &3564 & &0.0 & & & 1.7 &
& & ? & & & &Sl & & & &20:41 0:00 htt_server -nodaemon
root & & &3574 & &0.0 & & & 0.4 & &
& & ? & & & &Ss & & & 20:41 0:00 crond
xfs & & & &3617 & &0.0 & & & 1.3 &
& & ? & & & &Ss & & & 20:41 0:00 xfs -droppriv -daemon
root & & & 3627 & 0.0 & & & 0.2 & & 3448 & &552 & & ? & & & &SNs & & 20:41 0:00 anacron -s
root & & &3636 & &0.0 & & & 0.1 & & 2304 & &420 & & ? & & & &Ss & & & 20:41 0:00 /usr/sbin/atd
dbus & &3655 & &0.0 & & & 0.5 &
& & ? & & & &Ssl & & & 20:41 0:00 dbus-daemon-1 --system
....................................
stat 中的参数意义如下:
& &D 不可中断 Uninterruptible(usually IO)
& &R 正在运行,或在队列中的进程
& &S 处于休眠状态
& &T 停止或被追踪
& &Z 僵尸进程
& &W 进入内存交换(从内核2.6开始无效)
& &X & 死掉的进程
& & & 高优先级
& & n & 低优先级
& & s & 包含子进程
& & + & 位于后台的进程组
======================================
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而ps命令就是最基本同时也是非常强大的进程查看命令.使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵尸、哪些进程占用了过多的资源等等.总之大部分信息都是可以通过执行该命令得到的.
ps命令最常用的还是用于监控后台进程的工作情况,因为后台进程是不和屏幕键盘这些标准输入/输出设备进行通信的,所以如果需要检测其情况,便可以使用ps命令了.
& & & & &1)ps a 显示现行终端机下的所有程序,包括其他用户的程序。
2)ps -A 显示所有程序。
3)ps c 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。
4)ps -e 此参数的效果和指定&A&参数相同。
5)ps e 列出程序时,显示每个程序所使用的环境变量。
6)ps f 用ASCII字符显示树状结构,表达程序间的相互关系。
7)ps -H 显示树状结构,表示程序间的相互关系。
8)ps -N 显示所有的程序,除了执行ps指令终端机下的程序之外。
9)ps s 采用程序信号的格式显示程序状况。
10)ps S 列出程序时,包括已中断的子程序资料。
11)ps -t&终端机编号&  指定终端机编号,并列出属于该终端机的程序的状况。
12)ps u  以用户为主的格式来显示程序状况。
13)ps x  显示所有程序,不以终端机来区分。
最常用的方法是ps -aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。
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
注: 其它状态还包括W(无驻留页), &(高优先级进程), N(低优先级进程), L(内存锁页).
使用ps格式输出来查看进程状态:
ps -eo user,stat..,cmd
user 用户名
uid 用户号
pid 进程号
ppid 父进程号
size 内存大小, Kbytes字节.
vsize 总虚拟内存大小, bytes字节(包含code+data+stack)
share 总共享页数
nice 进程优先级(缺省为0, 最大为-20)
priority(pri) 内核调度优先级
pmem 进程分享的物理内存数的百分比
trs 程序执行代码驻留大小
rss 进程使用的总物理内存数, Kbytes字节
time 进程执行起到现在总的CPU暂用时间
stat 进程状态
cmd(args) 执行命令的简单格式
查看当前系统进程的uid,pid,stat,pri, 以uid号排序.
ps -eo pid,stat,pri,uid –sort uid
查看当前系统进程的user,pid,stat,rss,args, 以rss排序.
ps -eo user,pid,stat,rss,args –sort rss
使用权限:所有使用者
使用方式:ps [options] [--help]
说明:显示瞬间行程 (process) 的动态
ps 的参数非常多, 在此仅列出几个常用的参数并大略介绍含义
-A 列出所有的行程
-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程
au(x) 输出格式 :
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
USER: 行程拥有者
%CPU: 占用的 CPU 使用率
%MEM: 占用的记忆体使用率
VSZ: 占用的虚拟记忆体大小
RSS: 占用的记忆体大小
TTY: 终端的次要装置号码 (minor device number of tty)
STAT: 该行程的状态:
D: 不可中断的静止
R: 正在执行中
S: 静止状态
T: 暂停执行
Z: 不存在但暂时无法消除
W: 没有足够的记忆体分页可分配
&: 高优先序的行程
N: 低优先序的行程
L: 有记忆体分页分配并锁在记忆体内
START: 行程开始时间
TIME: 执行的时间
COMMAND:所执行的指令
PID TTY TIME CMD
2791 ttyp0 00:00:00 tcsh
3092 ttyp0 00:00:00 ps
PID TTY TIME CMD
1 ? 00:00:03 init
2 ? 00:00:00 kflushd
3 ? 00:00:00 kpiod
4 ? 00:00:00 kswapd
5 ? 00:00:00 mdrecoveryd
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.7
? S Sep10 0:03 init [3]
root 2 0.0 0.0 0 0 ? SW Sep10 0:00 [kflushd]
root 3 0.0 0.0 0 0 ? SW Sep10 0:00 [kpiod]
root 4 0.0 0.0 0 0 ? SW Sep10 0:00 [kswapd]
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是可以通过执行该命令得到的。
ps 为我们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;如果想对进程时间监控,应该用 top 工具。
kill 用于杀死进程。
1、ps 的参数说明
ps 提供了很多的选项参数,常用的有以下几个:
l 长格式输出;
u 按用户名和启动时间的顺序来显示进程;
j 用任务格式来显示进程;
f 用树形格式来显示进程;
a 显示所有用户的所有进程(包括其它用户);
x 显示无控制终端的进程;
r 显示运行中的进程;
ww 避免详细参数被截断;
我们常用的选项是组合是 aux 或 lax,还有参数 f 的应用。
2、ps aux 或 lax 输出的解释
USER 进程的属主;
PID 进程的ID;
PPID 父进程;
%CPU 进程占用的CPU百分比;
%MEM 占用内存的百分比;
NI 进程的NICE值,数值大,表示较少占用CPU时间;
VSZ 进程虚拟大小;
RSS 驻留中页的数量;
TTY 终端ID
STAT 进程状态(有以下几种)
D 无法中断的休眠状态(通常 IO 的进程);
R 正在运行可中在队列中可过行的;
S 处于休眠状态;
T 停止或被追踪;
W 进入内存交换(从内核2.6开始无效);
X 死掉的进程(从来没见过);
Z 僵尸进程;
& 优先级高的进程
N 优先级较低的进程
L 有些页被锁进内存;
s 进程的领导者(在它之下有子进程);
l 多进程的(使用 CLONE_THREAD, 类似 NPTL pthreads);
+ 位于后台的进程组;
WCHAN 正在等待的进程资源;
START 启动进程的时间;
TIME 进程消耗CPU的时间;
COMMAND 命令的名称和参数;
3、应用举例
[root@localhost ~]# ps -aux |more
可以用 | 管道和 more 连接起来分页查看。
[root@localhost ~]# ps -aux & ps001.txt
[root@localhost ~]# more ps001.txt
这里是把所有进程显示出来,并输出到ps001.txt文件,然后再通过more 来分页查看。
4、kill 终止进程
有十几种控制进程的方法,下面是一些常用的方法:
kill -STOP [pid]
发送SIGSTOP (17,19,23)停止一个进程,而并不消灭这个进程。
kill -CONT [pid]
发送SIGCONT (19,18,25)重新开始一个停止的进程。
kill -KILL [pid]
发送SIGKILL (9)强迫进程立即停止,并且不实施清理操作。
kill -9 -1
终止你拥有的全部进程。
SIGKILL 和 SIGSTOP 信号不能被捕捉、封锁或者忽略,但是,其它的信号可以。所以这是你的终极武器。
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:119594次
积分:1763
积分:1763
排名:第18403名
原创:35篇
转载:158篇
(2)(1)(6)(1)(2)(2)(6)(9)(37)(21)(4)(11)(5)(8)(19)(8)(9)(33)(10)

我要回帖

更多关于 渣尽千帆by北叶枫微盘 的文章

 

随机推荐