博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux常用命令——ps
阅读量:4053 次
发布时间:2019-05-25

本文共 6862 字,大约阅读时间需要 22 分钟。

转自:

Linux操作系统PS命令详细解析

要对系统中进程进行监测控制,用 ps 命令满足你。

/bin/ps

ps 是显示瞬间行程的状态,并不动态连续;如果想对进程运行时间监控,应该用 top 工具。

kill 用于杀死进程。

==============ps 的参数说明============================

l 长格式输出;

u 按用户名和启动时间的顺序来显示进程;

j 用任务格式来显示进程;

f 用树形格式来显示进程;

a 显示所有用户的所有进程(包括其它用户);

x 显示无控制终端的进程;

r 显示运行中的进程;

ww 避免详细参数被截断;

-A 列出所有的行程
-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程

-e 显示所有进程,环境变量

-f 全格式
-h 不显示标题
-l 长格式
-w 宽输出
  显示终端上地所有进程,包括其他用户地进程
  只显示正在运行地进程
  显示没有控制终端地进程

我们常用的选项是组合是 aux 或 lax,还有参数 f 的应用。

O[+|-] k1 [,[+|-] k2 [,…]] 根据SHORT KEYS、k1、k2中快捷键指定地多级排序顺序显示进程列表.

对于ps地不同格式都存在着默认地顺序指定.这些默认顺序可以被用户地指定所覆盖.在这里面“+”字符是可选地,“-”字符是倒转指定键地方向.
pids只列出进程标识符,之间运用逗号分隔.该进程列表必须在命令行参数地最后一个选项后面紧接着给出,中间不能插入空格.比如:ps -f1,4,5.

下介绍长命令行选项,这些选项都运用“--”开头:

--sort X[+|-] key [,[+|-] key [,…]] 从SORT KEYS段中选一个多字母键.“+”字符是可选地,因为默认地方向就是按数字升序或者词典顺序.比如: ps -jax -sort=uid,-

ppid,+pid.

--help 显示帮助信息.
--version 显示该命令地版本信息.

在前面地选项说明中提到了排序键,接下来对排序键作进一步说明.需要注意地是排序中运用地值是ps运用地内部值,并非仅用于某些输出格式地伪值.排序键列表见下表.

============排序键列表==========================

c cmd   可执行地简单名称
C cmdline   完整命令行
f flags   长模式标志
g pgrp   进程地组ID
G tpgid   控制tty进程组ID
j cutime   累计用户时间
J cstime   累计系统时间
k utime   用户时间
K stime   系统时间
m min_flt   次要页错误地数量
M maj_flt   重点页错误地数量
n cmin_flt 累计次要页错误
N cmaj_flt 累计重点页错误
o session   对话ID
p pid   进程ID
P ppid   父进程ID
r rss   驻留大小
R resident 驻留页
s size   内存大小(千字节)
S share   共享页地数量
t tty   tty次要设备号
T start_time 进程启动地时间
U uid   UID
u user   用户名
v vsize   总地虚拟内存数量(字节)
y priority 内核调度优先级
================================================

=================ps aux 或 lax 输出的解释=========================

2、ps aux 或 lax 输出的解释

au(x) 输出格式 :

USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
USER: 进程所有者
PID: 进程ID

%CPU: 占用的 CPU 使用率

%MEM: 占用的内存使用率
VSZ: 占用的虚拟内存大小
RSS: 占用的内存大小

TTY: 终端的次要装置号码 (minor device number of tty)

STAT: 进程状态:

START: 启动进程的时间;

TIME: 进程消耗CPU的时间;
COMMAND:命令的名称和参数;

=================进程STAT状态====================

D 无法中断的休眠状态(通常 IO 的进程);

R 正在运行,在可中断队列中;
S 处于休眠状态,静止状态;
T 停止或被追踪,暂停执行;
W 进入内存交换(从内核2.6开始无效);
X 死掉的进程;
Z 僵尸进程不存在但暂时无法消除;

W: 没有足够的记忆体分页可分配

WCHAN 正在等待的进程资源;

<: 高优先级进程

N: 低优先序进程
L: 有记忆体分页分配并锁在记忆体内 (即时系统或捱A I/O),即,有些页被锁进内存
s 进程的领导者(在它之下有子进程);
l 多进程的(使用 CLONE_THREAD, 类似 NPTL pthreads);
+ 位于后台的进程组;

================kill 终止进程=========================

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 信号不能被捕捉、封锁或者忽略,但是,其它的信号可以。所以这是你的终极武器。

=================范例========================

$ ps

PID TTY TIME COMMAND
5800 ttyp0 00:00:00 bash
5835 ttyp0 00:00:00 ps
可以看到,显示地项目共分为四项,依次为PID(进程ID)、TTY(终端名称)、TIME(进程执行时间)、COMMAND(该进程地命令行输入).

可以运用u选项来查看进程所有者及其他少许详细信息,如下所示:

$ ps u
USER PID %CPU %MEM USZ RSS TTY STAT START TIME COMMAND
test 5800 0.0 0.4 1892 1040 ttyp0 S Nov27 0:00 -bash
test 5836 0.0 0.3 2528 856 ttyp0 R Nov27 0:00 ps u

在bash进程前面有条横线,意味着该进程便是用户地登录shell,所以对于一个登录用户来说带短横线地进程只有一个.还可以看到%CPU、%MEM两个选项,前者指该进程占用地CPU时间

和总时间地百分比;后者指该进程占用地内存和总内存地百分比.

在这种情况下看到了所有控制终端地进程;当然对于其他那些没有控制终端地进程还是没有观察到,所以这时就需要运用x选项.运用x选项可以观察到所有地进程情况.

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去查找特定的进程,然后再对特定的进程进行操作。

转自:

ps:将某个时间点的程序运作情况撷取下来

[root
@linux 
~]
# ps aux
[root
@linux 
~]
# ps -lA
[root
@linux 
~]
# ps axjf
参数:
-
A 
:所有的 process 均显示出来,与 -e 具有同样的效用;
-a :不与 terminal 有关的所有 process ;
-u :有效使用者 (effective user) 相关的 process ;
x :通常与 a 这个参数一起使用,可列出较完整信息。
输出格式规划:
l :较长、较详细的将该
PID 
的的信息列出;
j :工作的格式 (jobs format)
-f :做一个更为完整的输出。
特别说明:
由于 ps 能够支持的
OS 
类型相当的多,所以他的参数多的离谱!
而且有没有加上 - 差很多!详细的用法应该要参考 man ps 喔!

 

范例1:将目前属于您自己这次登入的 PID 与相关信息列示出来

 

[root
@linux 
~]
# ps -l
F 
S 
UID 
PID 
PPID 
C 
PRI 
NI 
ADDR 
SZ 
WCHAN 
TTY 
TIME 
CMD
0 
S 
0 
5881 
5654 
0 
76 
0 
-
1303 
wait pts/
0 
00
:
00
:
00 
su
4 
S 
0 
5882 
5881 
0 
75 
0 
-
1349 
wait pts/
0 
00
:
00
:
00 
bash
4 
R 
0 
6037 
5882 
0 
76 
0 
-
1111 
- pts/
0 
00
:
00
:
00 
ps

 

# 上面这个信息其实很多喔!各相关信息的意义为:
# F 代表这个程序的旗标 (flag), 4 代表使用者为 super user;
# S 代表这个程序的状态 (STAT),关于各 STAT 的意义将在内文介绍;
# PID 没问题吧!?就是这个程序的 ID 啊!底下的 PPID 则上父程序的 ID;
# C CPU 使用的资源百分比
# PRI 这个是 Priority (优先执行序) 的缩写,详细后面介绍;
# NI 这个是 Nice 值,在下一小节我们会持续介绍。
# ADDR 这个是 kernel function,指出该程序在内存的那个部分。如果是个 running
# 的程序,一般就是『 - 』的啦!
# SZ 使用掉的内存大小;
# WCHAN 目前这个程序是否正在运作当中,若为 - 表示正在运作;
# TTY 登入者的终端机位置啰;
# TIME 使用掉的 CPU 时间。
# CMD 所下达的指令为何!?
# 仔细看到每一个程序的 PID 与 PPID 的相关性为何喔!上头列出的三个程序中,
# 彼此间可是有相关性的吶!

 

 

范例2:列出目前所有的正在内存当中的程序

 

[root
@linux 
~]
# ps aux
USER 
PID 
%
CPU 
%
MEM 
VSZ 
RSS 
TTY 
STAT 
START 
TIME 
COMMAND
root
1 
0
.
0 
0
.
1 
1740 
540 
?
S 
Jul25
0
:
01 
init [
3
]
root
2 
0
.
0 
0
.
0 
0 
0 
?
SN 
Jul25
0
:
00 
[ksoftirqd/
0
]
root
3 
0
.
0 
0
.
0 
0 
0 
?
S
< Jul25
0
:
00 
[events/
0
]
.....中间省略.....
root
5881 
0
.
0 
0
.
3 
5212 
1204 
pts/
0 
S 
10
:
22 
0
:
00 
su
root
5882 
0
.
0 
0
.
3 
5396 
1524 
pts/
0 
S 
10
:
22 
0
:
00 
bash
root
6142 
0
.
0 
0
.
2 
4488 
916 
pts/
0 
R
+
11
:
45 
0
:
00 
ps aux

 

 

USER
:该 process 属于那个使用者账号的?
PID 
:该 process 的号码。
• %
CPU
:该 process 使用掉的
CPU 
资源百分比;
• %
MEM
:该 process 所占用的物理内存百分比;
VSZ 
:该 process 使用掉的虚拟内存量 (Kbytes)
RSS 
:该 process 占用的固定的内存量 (Kbytes)
TTY 
:该 process 是在那个终端机上面运作,若与终端机无关,则显示 ?,另外, tty1-tty6 是本机上面的登入者程序,若为 pts/
0 
等等的,则表示为由网络连接进主机的程序。
STAT
:该程序目前的状态,主要的状态有:
o
R 
:该程序目前正在运作,或者是可被运作;
o
S 
:该程序目前正在睡眠当中 (可说是 idle 状态啦!),但可被某些讯号 (signal) 唤醒。
o
T 
:该程序目前正在侦测或者是停止了;
o
Z 
:该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
START
:该 process 被触发启动的时间;
TIME 
:该 process 实际使用
CPU 
运作的时间。
COMMAND
:该程序的实际指令为何?

 

 

 

 

范例3:以范例一的显示内容,显示出所有的程序

 

[root
@linux 
~]
# ps -lA
F 
S 
UID 
PID 
PPID 
C 
PRI 
NI 
ADDR 
SZ 
WCHAN 
TTY 
TIME 
CMD
4 
S 
0 
1 
0 
0 
76 
0 
-
435 
- ?
00
:
00
:
01 
init
1 
S 
0 
2 
1 
0 
94 
19 
-
0 
ksofti ?
00
:
00
:
00 
ksoftirqd/
0
1 
S 
0 
3 
1 
0 
70 
-
5 
-
0 
worker ?
00
:
00
:
00 
events/
0
.....以下省略.....

 

 

范例4:列出类似程序树的程序显示

 

[root
@linux 
~]
# ps -axjf
PPID 
PID 
PGID 
SID 
TTY 
TPGID 
STAT 
UID 
TIME 
COMMAND
0 
1 
0 
0 
? -
1 
S 
0 
0
:
01 
init [
3
]
1 
2 
0 
0 
? -
1 
SN 
0 
0
:
00 
[ksoftirqd/
0
]
.....中间省略.....
1 
5281 
5281 
5281 
? -
1 
Ss
0 
0
:
00 
/usr/sbin/sshd
5281 
5651 
5651 
5651 
? -
1 
Ss
0 
0
:
00 
\
_ 
sshd: dmtsai [priv]
5651 
5653 
5651 
5651 
? -
1 
S 
500 
0
:
00 
\
_ 
sshd: dmtsai
@pts
/
0
5653 
5654 
5654 
5654 
pts/
0 
6151 
Ss
500 
0
:
00 
\
_ 
-bash
5654 
5881 
5881 
5654 
pts/
0 
6151 
S 
0 
0
:
00 
\
_ 
su
5881 
5882 
5882 
5654 
pts/
0 
6151 
S 
0 
0
:
00 
\
_ 
bash
5882 
6151 
6151 
5654 
pts/
0 
6151 
R
+
0 
0
:
00 
\
_ 
ps -axjf

 

 

范例5:找出与 cron 与 syslog 这两个服务有关的 PID 号码

[root
@linux 
~]
# ps aux | egrep '(cron|syslog)'
root
1539 
0
.
0 
0
.
1 
1616 
616 
? Ss Jul25
0
:
03 
syslogd -m
0
root
1676 
0
.
0 
0
.
2 
4544 
1128 
? Ss Jul25
0
:
00 
crond
root
6157 
0
.
0 
0
.
1 
3764 
664 
pts/
0 
R
+
12
:
10 
0
:
00 
egrep (cron|syslog)

 

在预设的情况下, ps 仅会列出与目前所在的 bash shell 有关的 PID 而已,所以, 当我使用 ps -l 的时候,只有三个 PID (范例一)。

转载地址:http://mexci.baihongyu.com/

你可能感兴趣的文章
二叉树的非递归遍历
查看>>
【leetcode】Reorder List (python)
查看>>
【leetcode】Linked List Cycle (python)
查看>>
【leetcode】Linked List Cycle (python)
查看>>
【leetcode】Candy(python)
查看>>
【leetcode】Clone Graph(python)
查看>>
【leetcode】Sum Root to leaf Numbers
查看>>
【leetcode】Pascal's Triangle II (python)
查看>>
java自定义容器排序的两种方法
查看>>
如何成为编程高手
查看>>
本科生的编程水平到底有多高
查看>>
AngularJS2中最基本的文件说明
查看>>
从头开始学习jsp(2)——jsp的基本语法
查看>>
使用与或运算完成两个整数的相加
查看>>
备忘:java中的递归
查看>>
DIV/CSS:一个贴在左上角的标签
查看>>
Solr及Spring-Data-Solr入门学习
查看>>
Vue组件
查看>>
python_time模块
查看>>
python_configparser(解析ini)
查看>>