shell中的ps命令详解

ps简介:

Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是可以通过执行该命令得到的。


对系统中进程进行监测控制,查看状态,内存,CPU的使用情况,使用命令:/bin/ps
(1) ps :是显示瞬间进程的状态,并不动态连续;
(2) top:如果想对进程运行时间监控,应该用 top 命令;



ps 为我们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;如果想对进程时间监控,应该用 top 工具

命令行格式:

名称:ps
使用权限:所有使用者
使用方式:ps [options] [--help]
说明:显示瞬间行程 (process) 的动态
参数:ps的参数非常多, 在此仅列出几个常用的参数并大略介绍含义
-A 列出所有的进程
-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程

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


ps常用参数举例:

1,基本ps使用:

$ ps


结果默认会显示4列信息。

PID: 运行着的命令(CMD)的进程编号
TTY: 命令所运行的位置(终端)
TIME: 运行着的该命令所占用的CPU处理时间
CMD: 该进程所运行的命令
这些信息在显示时未排序。


2,列出目前所有的正在内存当中的程序。也许你希望把结果按照 CPU 或者内存用量来筛选,这样你就找到哪个进程占用了你的资源。要做到这一点,我们可以使用 aux 参数,来显示全面的信息:

$ ps -aux


Head标头:
USER 用户名
UID 用户ID(User ID)
PID 进程ID(Process ID)
PPID 父进程的进程ID(Parent Process id)
SID 会话ID(Session id)
%CPU 进程的cpu占用率
%MEM 进程的内存占用率
VSZ 进程所使用的虚存的大小(Virtual Size)
RSS 进程使用的驻留集大小或者是实际内存的大小,Kbytes字节。
TTY 与进程关联的终端(tty)
STAT 进程的状态:进程状态使用字符表示的(STAT的状态码)
R 运行 Runnable (on run queue) 正在运行或在运行队列中等待。
S 睡眠 Sleeping 休眠中, 受阻, 在等待某个条件的形成或接受到信号。
I 空闲 Idle
Z 僵死 Zombie(a defunct process) 进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放。
D 不可中断 Uninterruptible sleep (ususally IO) 收到信号不唤醒和不可运行, 进程必须等待直到有中断发生。
T 终止 Terminate 进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行。
P 等待交换页
W 无驻留页 has no resident pages 没有足够的记忆体分页可分配。
X 死掉的进程
< 高优先级进程 高优先序的进程
N 低优先 级进程 低优先序的进程
L 内存锁页 Lock 有记忆体分页分配并缩在记忆体内
s 进程的领导者(在它之下有子进程);
l 多进程的(使用 CLONE_THREAD, 类似 NPTL pthreads)
+ 位于后台的进程组
START 进程启动时间和日期
TIME 进程使用的总cpu时间
COMMAND 正在执行的命令行命令
NI 优先级(Nice)
PRI 进程优先级编号(Priority)
WCHAN 进程正在睡眠的内核函数名称;该函数的名称是从/root/system.map文件中获得的。
FLAGS 与进程相关的数字标识

4. 可以用 | 管道和 more 连接起来分页查看。
命令:ps -aux |more


5. 把所有进程显示出来,并输出到ps001.txt文件
命令:ps -aux > ps001.txt


6. 输出指定的字段
命令:ps -o pid,ppid,pgrp,session,tpgid,comm


7,根据 CPU 使用来升序排序

$ ps -aux --sort -pcpu | less


8,根据 内存使用 来升序排序
$ ps -aux --sort -pmem | less


9,树形显示进程

$ pstree


10,查看特定用户进程

在需要查看特定用户进程的情况下,我们可以使用 -u 参数。比如我们要查看用户'pungki'的进程,可以通过下面的命令:

$ ps -u pungki


11,通过进程名和PID过滤
使用 -C 参数,后面跟你要找的进程的名字。比如想显示一个名为getty的进程的信息,就可以使用下面的命令:

$ ps -C getty


12,显示所有进程信息,连同命令行

命令:ps -ef

  • 7
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: grep是一个常用的命令行工具,用于在文件搜索匹配某个模式的行。以下是grep命令的常见用法: 基本语法: ``` grep [options] pattern [file...] ``` 常见选项: - `-i`:忽略大小写 - `-v`:只匹配不包含模式的行 - `-n`:打印匹配行的行号 - `-r`:递归地搜索目录下的所有文件 - `-w`:只匹配整个单词,而不是单词的一部分 示例用法: 1. 在文件查找某个关键词: ``` grep "keyword" file.txt ``` 2. 忽略大小写查找: ``` grep -i "keyword" file.txt ``` 3. 查找不包含某个关键词的行: ``` grep -v "keyword" file.txt ``` 4. 递归搜索目录下的所有文件: ``` grep -r "keyword" /path/to/directory ``` 5. 只匹配整个单词: ``` grep -w "word" file.txt ``` 以上是grep命令的常见用法,可以根据需要添加其他选项来实现更复杂的搜索功能。 ### 回答2: grep命令是Linux下一个非常强大的文本搜索工具,常用于在文件查找指定字符串。它可以用于文本搜索,查找符合某种模式的行、列和自定界符隔开的数据记录等。 grep命令的基本语法格式是: grep [options] pattern [files] 其,pattern指定要搜索的模式或正则表达式。files指定要搜索的文件列表。options则是一些可选的参数,如-i忽略大小写,-c显示匹配行数,-v显示不匹配行等。 grep命令还有一些常用选项,比如: -n:显示匹配行的行号; -r:递归搜索,可查找目录及其子目录下的文件; -l:只显示匹配的文件名; -w:匹配整个单词而不是字符串片段; -x:只匹配整行而不是字符串片段。 另外,grep命令还支持正则表达式的高级搜索功能,通过正则表达式的语法,可以更精确地搜索文本内容。例如: -grep -E '[a-z]+@[a-z]+.com':搜索以字母开头、@符号、字母结尾并以“.com”结尾的字符串。 grep命令不仅可以在文件搜索文本,还可以和其他命令结合使用。比如,通过管道符号将grep命令的输出传递给其他命令,可以实现更多的搜索和过滤功能。 最后,grep命令是一个非常实用的命令行工具,可用于各种文本处理任务,包括搜索和过滤文件内容等,熟练掌握grep命令,可以提高工作效率。 ### 回答3: 在Linux的shell,grep是一款非常强大的命令行工具。它可以在文件或标准输入搜索特定的文本模式,并输出匹配结果。 grep命令语法格式如下: grep [option] pattern [file] 其,pattern为要搜索的文本模式,可以是一个字符串或正则表达式。file为要搜索的文件名,可以省略表示从标准输入读取。 接下来我们来详细解析grep命令的常用选项和用法: 1.基本搜索 在命令行输入如下命令: grep pattern file 其,pattern为要搜索的文本模式,file为要搜索的文件名。 例如,我们要在文件搜索所有包含"hello"的行,可以使用下面的命令: grep "hello" test.txt 该命令将在test.txt文件搜索所有包含"hello"的行,并将结果输出到标准输出。 2.忽略大小写搜索 通过使用选项-i,可以忽略搜索时的大小写。 例如,我们要在文件搜索所有包含"hello"的行,无论大小写如何,可以使用下面的命令: grep -i "hello" test.txt 该命令将在test.txt文件搜索所有包含"hello"的行,忽略大小写,并将结果输出到标准输出。 3.正则表达式搜索 通过使用选项-E,可以启用扩展正则表达式(ERE)的支持。 例如,我们要在文件搜索所有以字母"h"开头的单词,可以使用下面的命令: grep -E "\bh\w+" test.txt 该命令将在test.txt文件搜索所有以字母"h"开头的单词,并将结果输出到标准输出。 4.递归搜索 通过使用选项-r,可以递归搜索指定目录下的所有文件。 例如,我们要在当前目录下的所有文件搜索所有包含"hello"的行,可以使用下面的命令: grep -r "hello" . 该命令将在当前目录下的所有文件搜索所有包含"hello"的行,并将结果输出到标准输出。 5.计数搜索 通过使用选项-c,可以输出匹配行的数量。 例如,我们要在文件搜索所有包含"hello"的行,并输出行数,可以使用下面的命令: grep -c "hello" test.txt 该命令将在test.txt文件搜索所有包含"hello"的行,并输出行数。 以上是grep命令的常用选项和用法,希望能够对大家使用Linux的过程有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SaiW-n_n-

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值