【开发心得】使用grep查看指定日志

这两天跟甲方客户走的比较近,这老哥以前是开发,后期转运维了,平常我都是使用 vim 去模糊搜索,或者 tail -f | grep 'xxx'的方式去查看,但是看到老哥单独使用grep命令就能各种查看日志,所以特意找了一些文章来学习下,下面是转的别人的博客。

 

一 tail 命令
例如查看 catalina.out 后50行日志
[color=darkred]tail -50f catalina.out[/color]

[img]http://dl2.iteye.com/upload/attachment/0126/3510/06af93b4-649b-3c07-babf-e0433d4c27a6.png[/img]


二grep命令:grep可以对日志的关键行提取
a 不要忽略二进制数据。
-A<显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容。
-b 在显示符合范本样式的那一行之外,并显示该行之前的内容。
-c 计算符合范本样式的列数。
-C<显示列数>或-<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。
-d<进行动作> 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep命令将回报信息并停止动作。
-e<范本样式> 指定字符串作为查找文件内容的范本样式。
-E 将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。
-f<范本文件> 指定范本文件,其内容有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每一列的范本样式。
-F 将范本样式视为固定字符串的列表。 -G 将范本样式视为普通的表示法来使用。
-h 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。
-H 在显示符合范本样式的那一列之前,标示该列的文件名称。
-i 胡列字符大小写的差别。
-l 列出文件内容符合指定的范本样式的文件名称。
-L 列出文件内容不符合指定的范本样式的文件名称。
-n 在显示符合范本样式的那一列之前,标示出该列的编号。
-q 不显示任何信息。 -R/-r 此参数的效果和指定“-d recurse”参数相同。
-s 不显示错误信息。
-v 反转查找。

例如:查找ReserveProductService.update 字符串的前2行 或者后两行
[color=red]grep "ReserveProductService.update" catalina.out -n -B 2[/color]


[img]http://dl2.iteye.com/upload/attachment/0126/3508/114763ca-5067-3e66-ac1d-a8501e8015e5.png[/img]

或者
[color=darkred]grep "ReserveProductService.update" catalina.out -n -A 2[/color]


[img]http://dl2.iteye.com/upload/attachment/0126/3504/2d197a65-120a-3414-a9c7-bde5213dbf73.png[/img]


同时使用tail和grep 命令

例如:查询catalina.out文件的后500行中包含"GenericJDBCException" 字符串的前一行信息

[color=darkred]tail -500 catalina.out| grep -H -n -B 1 "GenericJDBCException"[/color]

[img]http://dl2.iteye.com/upload/attachment/0126/3506/b6696051-8fc5-3cb1-937f-f65da54ad5df.png[/img]

————————————————
版权声明:本文为CSDN博主「tj_boce_gjp」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/gjp014/article/details/84905522

posted @ 2020-07-04 20:39  虹梦未来  阅读(21)  评论(0编辑  收藏  举报  来源