grep [option] pattern filelinux
用于过滤/搜索的特定字符。可以使用正则表达式能多种命令配合使用,使用上十分灵活。git
Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是全部用户。正则表达式
grep的工做方式是这样的,它在一个或多个文件中搜索字符串模板。若是模板包括空格,则必须被引用,模板后的全部字符串被看做文件名。搜索的结果被送到标准输出,不影响原文件内容。shell
grep可用于shell脚本,由于grep经过返回一个状态值来讲明搜索的状态,若是模板搜索成功,则返回0,若是搜索不成功,则返回1,若是搜索的文件不存在,则返回2。咱们利用这些返回值就可进行一些自动化的文本处理工做。 ubuntu
-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”参数相同。
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)
查找指定进程个数
命令: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
Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,若是想要动态的显示进程信息,就可使用top命令。ps 为咱们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;若是想对进程时间监控,应该用 top 工具。
要对进程进行监测和控制,首先必需要了解当前进程的状况,也就是须要查看当前进程,而 ps 命令就是最基本同时也是很是强大的进程查看命令。使用该命令能够肯定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是能够经过执行该命令获得的。
linux上进程有5种状态:
ps工具标识进程的5种状态码:
ps [参数]
a 显示全部进程
-a 显示同一终端下的全部程序
-A 显示全部进程
c 显示进程的真实名称
-N 反向选择
-e 等于“-A”
e 显示环境变量
f 显示程序间的关系
-H 显示树状结构
r 显示当前终端的进程
T 显示当前终端的全部程序
u 指定用户的全部进程
-au 显示较详细的资讯
-aux 显示全部包含其余使用者的行程
-C<命令> 列出指定命令的情况
--lines<行数> 每页显示的行数
--width<字符数> 每页显示的字符数
--help 显示帮助信息
--version 显示版本显示
显示全部进程信息
命令: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:该程序的实际指令