基础!基础!还是基础!
程序员每天除了编写代码,还得面对的一个问题就是线上问题排查
线上问题排查,除了业务熟悉,操作熟练,还有很重要的一个依据就是文件日志
所以查找日志就显得尤为重要,尤其是现在绝大多数服务器都是部署在Linux操作系统上面,这就要求基本的Linux命令grep必须很熟练。
在这里推荐《鸟哥的Linux私房菜》!
grep基本用法
grep是一个选取命令
就是将一段数据进行分析,输出我们想要的。或者是根据关键字,取出我们想要的那一行。所以一般来说,选取信息通常是针对"行"来分析的,并不是整篇信息
基本语法
grep -[acinv] [--color=auto] '关键字' filename
参数说明:
- -a:将 binary 文件以text文件的方式查找数据
- -c:计算找到 '关键字' 的次数
- -i:忽略大小写的不太,所以大小写视为相同
- -n:输出行号
- -v:反向选择,即显示没有 '关键字的那一行'
- --color=auto:即将找到的关键字部分加上颜色显示
例子1:将 /etc/man.config 文件中包含 MANPATH的行
grep MANPATH man.conf
再试试"-n"输出行号,可以看到区别是输出带了行号
grep -n MANPATH man.conf
再试试"-i"忽略大小写,可以看到,小写的manpath这一行也显示出来了
grep -v MANPATH man.conf
再试试"-v"忽略大小写,可以发现输出的全部不包含MANPAHT
grep -v MANPATH man.conf
高级用法
grep [-A] [-B] '关键字' filename
参数说明:
-A:为after的意思,后面可加数字,除了列出该行外,后续的n行也列出
-B:为before的意思,后面可加数字,除了列出该行外,前面的n行也列出
比如打印出MANPATH的前后各3行
这个命令在查线上问题,尤其是异常堆栈的时候相当有用!
正则表达式
Linux上面的正则表达式规则其实跟其它的都差不多,最常见的几种
RE字符 | 意义 | 范例 | 命令 |
^word | 待查找的字符串(word)在行首 | 查找行首为#开始的那一行,并列出行号 | grep -n '^#' man.conf |
word$ | 待查找的字符串(word)在行尾 | 查找行尾为]的那一行,并列出行号 | grep ']$' man.conf --col --col |
. | 匹配一个任意字符 | 查找的字符串可以是eve,eae,eee,ee,但不能仅有ee,即e与e之间"一定"仅有一个字符,而空格符也是字符 | grep -n 'e.e' man.conf --col |
* | 重复零个到无穷多个的前一个字符 | ||
[list] | 从字符集合的RE字符串里面找出想要选取的字符 | 查找含有gl或gd的那一行,需要特别留意的是,的[]当中代表一个待查找的字符 | grep -n 'e[abln]e' man.conf --col |
\ | 转义字符,将特殊符号的特殊意义去除 | 查找含有单引号'的那一行 | grep -n \' man.conf --col |
[n1-n2] | 从字符集合的RE字符串里面找出想要选取的字符范围 | 查找含有任意数字的那一行。 在字符集合[]中的减号-是有特殊意义的,它代表两个字符之间的所有联系字符 | grep -n '[0-9]' man.conf --col |
正则表达式的特殊字符与一般在命令行输命令的"通配符"并不相同。例如在通配符当中的*代表的是零到无限多个字符的意思,但是在正则表达式当中,*则代码重复0到无穷多个的前一个RE字符的意思