Linux-(ps,grep)

grep命令

1.命令格式:

grep [option] pattern filelinux

2.命令功能:

用于过滤/搜索的特定字符。可以使用正则表达式能多种命令配合使用,使用上十分灵活。git

Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是全部用户。正则表达式

grep的工做方式是这样的,它在一个或多个文件中搜索字符串模板。若是模板包括空格,则必须被引用,模板后的全部字符串被看做文件名。搜索的结果被送到标准输出,不影响原文件内容。shell

grep可用于shell脚本,由于grep经过返回一个状态值来讲明搜索的状态,若是模板搜索成功,则返回0,若是搜索不成功,则返回1,若是搜索的文件不存在,则返回2。咱们利用这些返回值就可进行一些自动化的文本处理工做。 ubuntu

3.命令参数:

-a   --text   #不要忽略二进制的数据。   bash

-A<显示行数>   --after-context=<显示行数>   #除了显示符合范本样式的那一列以外,并显示该行以后的内容。   网络

-b   --byte-offset   #在显示符合样式的那一行以前,标示出该行第一个字符的编号。   session

-B<显示行数>   --before-context=<显示行数>   #除了显示符合样式的那一行以外,并显示该行以前的内容。   ssh

-c    --count   #计算符合样式的列数。   svn

-C<显示行数>    --context=<显示行数>或-<显示行数>   #除了显示符合样式的那一行以外,并显示该行以前后的内容。   

-d <动做>      --directories=<动做>   #当指定要查找的是目录而非文件时,必须使用这项参数,不然grep指令将回报信息并中止动做。   

-e<范本样式>  --regexp=<范本样式>   #指定字符串作为查找文件内容的样式。   

-E      --extended-regexp   #将样式为延伸的普通表示法来使用。   

-f<规则文件>  --file=<规则文件>   #指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。   

-F   --fixed-regexp   #将样式视为固定字符串的列表。   

-G   --basic-regexp   #将样式视为普通的表示法来使用。   

-h   --no-filename   #在显示符合样式的那一行以前,不标示该行所属的文件名称。   

-H   --with-filename   #在显示符合样式的那一行以前,表示该行所属的文件名称。   

-i    --ignore-case   #忽略字符大小写的差异。   

-l    --file-with-matches   #列出文件内容符合指定的样式的文件名称。   

-L   --files-without-match   #列出文件内容不符合指定的样式的文件名称。   

-n   --line-number   #在显示符合样式的那一行以前,标示出该行的列数编号。   

-q   --quiet或--silent   #不显示任何信息。   

-r   --recursive   #此参数的效果和指定“-d recurse”参数相同。   

-s   --no-messages   #不显示错误信息。   

-v   --revert-match   #显示不包含匹配文本的全部行。   

-V   --version   #显示版本信息。   

-w   --word-regexp   #只显示全字符合的列。   

-x    --line-regexp   #只显示全列符合的列。   

-y   #此参数的效果和指定“-i”参数相同。

4.规则表达式:

grep的规则表达式:

^  #锚定行的开始 如:'^grep'匹配全部以grep开头的行。    

$  #锚定行的结束 如:'grep$'匹配全部以grep结尾的行。    

.  #匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,而后是p。    

*  #匹配零个或多个先前字符 如:'*grep'匹配全部一个或多个空格后紧跟grep的行。    

.*   #一块儿用表明任意字符。   

[]   #匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep。    

[^]  #匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。    

\(..\)  #标记匹配字符,如'\(love\)',love被标记为1。    

\<      #锚定单词的开始,如:'\<grep'匹配包含以grep开头的单词的行。    

\>      #锚定单词的结束,如'grep\>'匹配包含以grep结尾的单词的行。    

x\{m\}  #重复字符x,m次,如:'0\{5\}'匹配包含5个o的行。    

x\{m,\}  #重复字符x,至少m次,如:'o\{5,\}'匹配至少有5个o的行。    

x\{m,n\}  #重复字符x,至少m次,很少于n次,如:'o\{5,10\}'匹配5--10个o的行。   

\w    #匹配文字和数字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零个或多个文字或数字字符,而后是p。   

\W    #\w的反置形式,匹配一个或多个非单词字符,如点号句号等。   

\b    #单词锁定符,如: '\bgrep\b'只匹配grep。  

POSIX字符:

为了在不一样国家的字符编码中保持一至,POSIX(The Portable Operating System Interface)增长了特殊的字符类,如[:alnum:]是[A-Za-z0-9]的另外一个写法。要把它们放到[]号内才能成为正则表达式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符类。

[:alnum:]    #文字数字字符   

[:alpha:]    #文字字符   

[:digit:]    #数字字符   

[:graph:]    #非空字符(非空格、控制字符)   

[:lower:]    #小写字符   

[:cntrl:]    #控制字符   

[:print:]    #非空字符(包括空格)   

[:punct:]    #标点符号   

[:space:]    #全部空白字符(新行,空格,制表符)   

[:upper:]    #大写字符   

[:xdigit:]   #十六进制数字(0-9,a-f,A-F)  

5.使用实例:

查找指定进程个数

命令:ps -ef|grep svn -c

从文件中读取关键词进行搜索

命令:cat test.txt | grep -f test2.txt

[root@localhost test]# cat test.txt 
hnlinux
peida.cnblogs.com
ubuntu
ubuntu linux
redhat
Redhat
linuxmint
[root@localhost test]# cat test2.txt 
linux Redhat
[root@localhost test]# cat test.txt | grep -f test2.txt
hnlinux
ubuntu linux
Redhat
linuxmint

grep不显示自己进程

命令:ps aux | grep ssh | grep -v "grep"

输出非u开头的行内容

命令:cat test.txt |grep ^[^u]

显示当前目录下面以.txt 结尾的文件中的全部包含每一个字符串至少有7个连续小写字符的字符串的行

命令:grep '[a-z]\{7\}' *.txt

ps命令

Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程若是想要动态的显示进程信息,就可使用top命令。ps 为咱们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;若是想对进程时间监控,应该用 top 工具。

要对进程进行监测和控制,首先必需要了解当前进程的状况,也就是须要查看当前进程,而 ps 命令就是最基本同时也是很是强大的进程查看命令。使用该命令能够肯定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是能够经过执行该命令获得的。

linux上进程有5种状态:

  • 运行(正在运行或在运行队列中等待)
  • 中断(休眠中, 受阻, 在等待某个条件的造成或接受到信号)
  • 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
  • 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
  • 中止(进程收到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 [参数]

2.命令参数:

a 显示全部进程

-a 显示同一终端下的全部程序

-A 显示全部进程

c 显示进程的真实名称

-N 反向选择

-e 等于“-A”

e 显示环境变量

f 显示程序间的关系

-H 显示树状结构

r 显示当前终端的进程

T 显示当前终端的全部程序

u 指定用户的全部进程

-au 显示较详细的资讯

-aux 显示全部包含其余使用者的行程

-C<命令> 列出指定命令的情况

--lines<行数> 每页显示的行数

--width<字符数> 每页显示的字符数

--help 显示帮助信息

--version 显示版本显示

4.使用实例:

显示全部进程信息

命令:ps -A

➜  ConfigCenter git:(develop) ps -A
  PID TTY           TIME CMD
    1 ??        55:10.49 /sbin/launchd
   41 ??         6:15.71 /usr/libexec/UserEventAgent (System)

显示指定用户信息

命令:ps -u root

显示全部进程信息,连同命令行

命令:ps -ef

➜  ConfigCenter git:(develop) ps -ef
  UID   PID  PPID   C STIME   TTY           TIME CMD
    0     1     0   0  7Mar17 ??        55:10.67 /sbin/launchd
    0    41     1   0  7Mar17 ??         6:15.72 /usr/libexec/UserEventAgent (System)
    0    42     1   0  7Mar17 ??        10:12.64 /usr/sbin/syslogd

目前属于您本身此次登入的 PID 与相关信息列示出来

命令:ps -l

列出目前全部的正在内存当中的程序

命令:ps aux

输出指定的字段

命令:ps -o pid,ppid,pgrp,session,tpgid,comm

[root@localhost test6]# ps -o pid,ppid,pgrp,session,tpgid,comm
  PID  PPID  PGRP  SESS TPGID COMMAND
17398 17394 17398 17398 17478 bash
17478 17398 17478 17398 17478 ps

 说明:

各相关信息的意义:

F 表明这个程序的旗标 (flag), 4 表明使用者为 super user

S 表明这个程序的状态 (STAT),关于各 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。

➜  ConfigCenter git:(develop) ps -l
  UID   PID  PPID        F CPU PRI NI       SZ    RSS WCHAN     S             ADDR TTY           TIME CMD
  501 36010 36004     4006   0  31  0  2463840   2824 -      S                   0 ttys001    0:02.83 -zsh
  501 36009 36007     4006   0  31  0  2463840    972 -      S+                  0 ttys002    0:00.91 -zsh
  501 45069 25366     4006   0  31  0  2463772    120 -      Ss+                 0 ttys003    0:00.31 /bin/zsh --login -i

说明:

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) 唤醒。

T :该程序目前正在侦测或者是中止了

Z :该程序应该已经终止,可是其父程序却没法正常的终止他,形成 zombie (疆尸) 程序的状态

START:该 process 被触发启动的时间

TIME :该 process 实际使用 CPU 运做的时间

COMMAND:该程序的实际指令

相关文章
相关标签/搜索