Linux ps命令:用于显示当前进程 (process) 的状态

Linux ps命令:用于显示当前进程 (process) 的状态,第1张

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

linux awk命令怎么用? awk:用于一行中分成数个“栏位”来处理。适合处理 小型资料。

执行模式:awk '条件型别1{动作1} 条件型别2{动作2} ...' filename

# last | awk '{print $1 "\t" $3}' <== 检视登入者的资料,只显示登入名和ip地址,并以[tab]隔开

awk 的内建变数

变数名称 代表的含义

NF 每一行($0)拥有的栏位总数

NR 当前 awk 所处理的是 “第几行” 资料

FS 当前分隔符,预设空格键

awk 的逻辑运算子

运算单元 代表含义

>大于

<小于

>= 大于或等于

<= 小于或等于

== 等于

!= 不等于

范例:

cat /etc/passwd | awk '{FS=":"} $3 <10 {print $1 "\t" $3}' <== 档案/etc/passwd是以":"分隔的,检视第三栏小于10的资料,并且只显示帐号与第三栏

以上是我对awk的总结,希望对你有帮助,是我写的哦,不是复制的。

linux 怎么用awk命令 取出一段文字

awk '/<DIMENSION NAME="CCCCCC" SRC_TYPE="INTERNAL">/,/<DIMENSIONS>/ {print $0}' filename

Linux awk命令问题

head -n 3 /etc/passwd|awk -F ':' '$1="root"' 这里$1="root",表示将第1列的值赋值为root,因此上述命令表示:将/etc/passwd中前3行按照‘:’分隔后第一列以root显示,并列印其他列。

awk -F ':' '$3=="0"' /etc/passwd

这里$3=="0",表示将第三列与"0”进行匹配,以什么方式匹配呢?以‘:’分隔后的第三列进行匹配并列印。这里是匹配列印,所以列印的是匹配的那一行(被:分隔后),而不是显示分隔后的列。

所以,区别在于一个是分隔后赋值列印分隔后列的值,一个是按照指定分隔方式进行匹配找到匹配的行,列印的是匹配的那一行。

linux的awk命令问题

一行里 第一个元素和第三个元素

linux下 awk命令问题

1、其实这样基本满足要求。但是确实不够严谨。试试是否可以。

ps -le | grep sshd | awk '{print $4}'

2、对ps 命令用的最多的是ps -ef 对el 我不是很了解具体输出什么。当然,是不是你压根就没有这个sshd服务启动。这些都先验证一下。一步一步的输出,看看问题出现在管道的哪一个环节。

3、或者这个 $14==sshd 栏位你指定错了。 awk $指定的变数是从1 开始的。$0是整个行。这个不要忘记了哦。

如果上述1第一种情况可以输出,第二种2不可以话,可能就验证了我的假设。你栏位拆解出现错误。把$14 这个栏位好好看看。

linux awk命令基础 怎么在终端写

awk一般用于文字处理,通常用作资料提取。终端书写demo

awk '{print }' info.txt

以上是输出文字档案info.txt的所有内容,请使用实际档案进行替换info.txt

ps -ef|grep process_name | awk -F"" '{print $2}'

以上是查询process_name程序的ID资讯,把查询资讯作为引数传给awk进行过滤,请使用实际程序名替换process_name。

awk命令在 linux和aix下的区别

三种呼叫awk的命令方式:

1.命令列方式:awk [-F field-separator] 'mands' input-file(s)

-F选项可选:awk -F: 'mands' input-file

2.将所有的awk命令插入一个档案,并是awk程式可执行,然后用awk命令直译器作为指令码的首行,

以便通过键入指令码名称来呼叫它。

3.将所有的awk命令插入一个单独档案,然后呼叫:

awk -f awk-script-file input-files(s)

-f:指明在档案awk-script-file中的awk指令码

input-file(s):使用awk进行浏览的档名。

awk指令码

在命令中呼叫awk时,awk指令码由各种 *** 作和模式组成。

-F,awk每次读一条记录或一行,并使用指定的分隔符分分隔指定域;

所没分隔符,则使用空格。

任何awk语句都由模式和动作组成

模式,决定动作语句何时触发及触发事件,若忽略模式部分,动作将时刻保持执行状态。

模式,可是任何条件语句,或符合语句,或正则表示式。

BEGIN:设定计数,列印头,在任何文字浏览动作之前;

END:用来在awk完成档案浏览动作后列印输出档案总数和结尾状态标志。

动作,在{}内指定;大多用来列印;里面可包含:if,looping,回圈推出结构;

若不指明采取动作,awk将列印所有浏览出来的记录。

如何在Linux中使用awk命令

awk例项

1、cat /etc/passwd|awk -F: '{print $1}'

2、linux的awk一般都是gawk,/bin/awk ->gawk

3、awk ‘/abc/’ file.txt 显示档案中包含abc行。类似grep abc a.txt

4、awk ‘{print NR,NF,$1,$NF,}’ file.txt按空格分隔列,显示当前记录号、域数和每一行的第一列和最后一列。

-F引数可以设定分割引数,例如按:分割

awk -F: ‘{print $1}’ /etc/passwd

或者cat file|awk -F “|” ‘{print $1}’

5、awk程式语言

cat v.txt|awk ‘{print length($1)}’

6、awk中使用NR和FNR,一般在awk处理多个档案时,NR==FNR才有意义

NF 当前记录中的栏位数。

NR 当前记录数。

FNR同NR,但相对于当前档案。

awk ‘{print NR,FNR}’ test.txt test2.txt

awk ‘{if(NR==FNR){a[FNR]=$1}else{print $1,a[FNR]}}’ b.txt a.txt

7、列印奇数行与偶数行

awk ‘NR%2’ test.txt

awk ‘!(NR%2)’ test.txt

8、杀死tomcat的s.sh指令码

#!/bin/sh

ps -ef| grep tomcat |grep -v grep | awk ‘{print $2}’ |xargs kill -9

9、列印前7列

cat a.txt|awk ‘{NF=7}1’ >>b.txt

tail -f aess.log|awk ‘NF=7′ OFS=’\t’ >>b.txt

cut -d”,” -f3-6 urfile

LINUX系统怎么使用awk命令实现下述 *** 作

cat file|awk -F"name=" '{print $2}'|awk -F\" '{print $1}'

试试看,第二个”的转义,我没测试,可以自己调下


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7340600.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-04
下一篇2023-04-04

发表评论

登录后才能评论

评论列表(0条)

    保存