Linux grep、tail命令的混合使用

2018-11-29  本文已影响284人  小小看护

grep

Linux grep命令用于查找文件里符合条件的字符串。
grep指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为"-",则grep指令会从标准输入设备读取数据。

语法

grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][--help][范本样式][文件或目录...]

grep [选项] "模式" [文件]

参数

  • -a 或 --text : 不要忽略二进制的数据。

实例

[root@hard supervisord]# grep 'POST.*play_order.*return 200' tmd.log
[2018-10-21 14:39:21,190] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-21 14:42:03,327] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-21 14:43:27,720] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-21 18:15:25,090] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-21 18:33:20,517] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-22 16:20:55,863] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-22 17:41:36,183] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-22 17:52:44,021] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200
[2018-10-22 17:55:15,172] [base.py:451  ] [DEBUG] [POST /adminapi/v3/play_order ] return 200

grep 'POST.*play_order.*return 200' tmd.log 这个等同于grep 'play_order' tmd.log | grep 'POST' | grep 'return 200'

[root@hard supervisord]# grep -c 'POST.*play_order.*return 200' tmd.log
62
[root@hard supervisord]# grep -c  'play_order' tmd.log  | grep 'POST' | grep 'return 200'
[root@hard supervisord]# grep  'play_order' tmd.log  | grep 'POST' | grep -c 'return 200'
62

grep可以和很多的命令一起使用

查看Linux 某些程序进程 ps aux 
[root@iZ2ze3269b etc]# ps aux | grep mysql
root      2371  0.0  0.0 112676   980 pts/0    S+   14:34   0:00 grep --color=auto mysql
mysql    10810  0.1  9.4 1599384 367788 ?      Sl   10月11  13:13 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid

tail

tail 命令可用于查看文件的内容,有一个常用的参数 -f 常用于查阅正在改变的日志文件。
tail -f filename 会把 filename 文件里的最尾部的内容显示在屏幕上,并且不断刷新,只要 filename 更新就可以看到最新的文件内容。

语法

tail [参数] [文件]

参数

  • -f 循环读取

实例

要显示 notes.log 文件的最后 10 行,请输入以下命令:

tail notes.log

要跟踪名为 notes.log 的文件的增长情况,请输入以下命令:

tail -f notes.log

此命令显示 notes.log 文件的最后 10 行。当将某些行添加至 notes.log 文件时,tail 命令会继续显示这些行。 显示一直继续,直到您按下(Ctrl-C)组合键停止显示。
显示文件 notes.log 的内容,从第 20 行至文件末尾:

tail +20 notes.log

混合使用

有时候我们会查询正在改变的文件,但是我们只想查看其中的某一些信息,这时候就可以使用tail、grep的混合使用

tail -f filename | grep 'DEBUG'

实例

tail -f tmd.log | grep 'DEBUG.template.begin'

上一篇 下一篇

猜你喜欢

热点阅读