同时满足多个关键字和满足任意关键字
grep -E "word1|word2|word3" *.log
必须同时满足三个条件(word1、word2和word3)才匹配
grep word1 file.txt | grep word2 |grep word3
使用tail时候不能用grep搜索
tail -f log | grep --line-buffer xxx | grep --line-buffer yyy
其他同样类似的操作有egrep,awk
正则表达式查找日志文件
grep [options] regex [files]
选项 | 含义 | 功能描述 |
-i | ignore case | 忽略大小写 |
-v | invert match | 不匹配匹配的 |
-l | file-with-match | 输出匹配的文件名 |
-L | file-without-match | 输出不匹配的文件名 |
-c | count | 输出匹配的数目(行数) |
-n | number | 输出匹配行的同时在前面加上文件名及在文件名中的行数 |
-h | no-filename | 抑制文件名的输出 |
特殊字符
符号 | 含义 | 举例 | ||
^ | 开始标记 | "^abc"满足的例子abc、abcd | ||
^ | 非(在[]内) | "[^abc]"满足的例子:ddd、mpd | ||
$ | 结束标记 | ”abc$”满足的例子abc、mmabc | ||
. | 任意字符 | "a.c"满足的例子abc、fapcc | ||
\< | 匹配单词开始 | "\<abc"满足的例子abc、abcd | ||
\> | 匹配单词结束 | "abc\>"满足的例子abc、pmrabc | ||
或 | "AAA | BBB"满足的例子AAA、BBBpp |
范围
符号 | 含义 | 举例 | |||
? | 匹配前一个字符0或1次 | "abc?"满足的例子ab、mabcd | |||
* | 匹配前一个字符≥0次 | "abc*"满足的例子abbb、abcdk | |||
+ | 匹配前一个字符≥1次 | "abc+"满足的例子abcd、abcccdd | |||
{} | {m}、{m,n}、{m,}、{,n}分别为匹配前一个字符m次、m到n次、≥m次、≤n次 | "abc\{3,5\}"满足的例子abcccc、abcccccc | |||
[] | []内如果不是范围,选其一;是范围的话,范围内选其一 | "m[abc]p"满足的例子acpd;m[1-9]p满足的例子m8pp | |||
() | 将候选的所有元素放在()内,用 | 隔开 | "a(1 | 2 | 3)bc"满足的例子a1bc、mba3bcd |
标准字符类
字符类 | 释义 |
[:alnum:] | 字母和数字,与[A-Za-z0-9]等价 |
[:word:] | [:alnum:]加上下划线_ |
[:alpa:] | 字母,与[A-Za-z]等价 |
[:digit:] | 数字,与[0-9]等价 |
[:xdigit:] | 十六进制字符,与[0-9A-Fa-f等价] |
[:blank:] | 空格和制表符 |
[:graph:] | 可见字符,靠扩33~126 |
[:lower:] | 小写字母 |
[:upper:] | 大写字母 |
[:print:] | 可打印字符 |
[:space:] | 空白字符,等价于[\t\r\n\v\f] |
[:punct:] | 标点符号 |
[:cntrl:] | ASCII控制码,包括字符0~31以及127 |