cat 命令(文本輸出命令)
通常查找出錯(cuò)誤日志 cat error.log | grep 'nick' , 這時(shí)候我們要輸出當(dāng)前這個(gè)日志的前后幾行:
- 顯示file文件里匹配nick那行以及上下5行
cat error.log | grep -C 5 'nick'
- 顯示nick及前5行
cat error.log | grep -B 5 'nick'
- cat error.log | grep -A 5 'nick'
顯示nick及后5行
less 命令(分頁(yè)查看文件內(nèi)容)
- 分頁(yè)查看日志,但是中文有亂碼
less error.log
- 直接定位到第100行
less +100g xx.log
- 定位到最后一行
less +GG xx.log
- 查找并高亮關(guān)鍵字
less fis.log.2018-05-20 | grep 2018052019004984219071028 -A 5 --color=auto
移動(dòng)日志
- G :到日志最后
- g :到日志最前面
- j/↑ :向前移動(dòng)一行
- k/↓ :向后移動(dòng)一行
- pgup :向上翻頁(yè)
- pgdn :向下翻頁(yè)
搜索所需內(nèi)容
- /nick:在日志文件中查找 nick
- n:向下查找下一個(gè)匹配的文本
- N: 向上查找下一個(gè)匹配的文本
tail 命令(顯示文件結(jié)尾)
- 顯示文件file的最后10行
tail file
- 滾動(dòng)輸出日志
tail -f
- 顯示日志文件最后500行日志
tail -n 500 file
- 顯示日志從20行至文件末尾
tail +20 file
grep 命令
grep 2018071018540800711006028 root.flog.2018-07-10-* | more
場(chǎng)景
按行號(hào)查看---過濾出關(guān)鍵字附近的日志
因?yàn)橥ǔr(shí)候我們用grep拿到的日志很少,我們需要查看附近的日志.我是這樣做的:
- 首先得到關(guān)鍵日志的行號(hào)
cat -n test.log |grep 地形
- 得到"地形"關(guān)鍵字所在的行號(hào)是102行. 此時(shí)如果我想查看這個(gè)關(guān)鍵字前10行和后10行的日志:
cat -n test.log |tail -n +92|head -n 20
tail -n +92表示查詢92行之后的日志
head -n 20 則表示在前面的查詢結(jié)果里再查前20條記錄
或者直接用這個(gè)命令
cat test.log | grep -C 10 地形
那么按日期怎么查呢? 通常我們非常需要查找指定時(shí)間端的日志
sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p' test.log
特別說明:
上面的兩個(gè)日期必須是日志中打印出來的日志,否則無效.
關(guān)于日期打印,可以先 grep '2014-12-17 16:17:20' test.log 來確定日志中是否有該時(shí)間點(diǎn)
如果我們查找的日志很多,打印在屏幕上不方便查看, 有兩個(gè)方法:
(1)使用more和less命令, 如:
cat -n test.log |grep "地形" | less
這樣就分頁(yè)打印了,通過點(diǎn)擊空格鍵翻頁(yè)
(2)使用 >xxx.txt 將其保存到文件中,到時(shí)可以拉下這個(gè)文件分析.如:
cat -n test.log |grep "地形" >xxx.txt
查找并分頁(yè)顯示
在test.log文件中的最后一萬行查找nick欢顷,并分頁(yè)顯示找到nick地方的上下5行
tail -n 10000 test.log | grep -C 5 nick| less