查看線上日志常用命令

cat 命令(文本輸出命令)

通常查找出錯誤日志 cat error.log | grep 'nick' , 這時候我們要輸出當前這個日志的前后幾行:

  • 顯示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 命令(分頁查看文件內(nèi)容)

  • 分頁查看日志,但是中文有亂碼
less error.log
  • 直接定位到第100行
less +100g xx.log
  • 定位到最后一行
less +GG xx.log
  • 查找并高亮關鍵字
less fis.log.2018-05-20  | grep 2018052019004984219071028 -A 5 --color=auto

移動日志

  • G :到日志最后
  • g :到日志最前面
  • j/↑ :向前移動一行
  • k/↓ :向后移動一行
  • pgup :向上翻頁
  • pgdn :向下翻頁

搜索所需內(nèi)容

  • /nick:在日志文件中查找 nick
  • n:向下查找下一個匹配的文本
  • N: 向上查找下一個匹配的文本

tail 命令(顯示文件結尾)

  • 顯示文件file的最后10行
tail file
  • 滾動輸出日志
tail -f
  • 顯示日志文件最后500行日志
tail -n 500 file
  • 顯示日志從20行至文件末尾
tail +20 file 

grep 命令

grep 2018071018540800711006028 root.flog.2018-07-10-* | more

場景

按行號查看---過濾出關鍵字附近的日志

因為通常時候我們用grep拿到的日志很少,我們需要查看附近的日志.我是這樣做的:

  1. 首先得到關鍵日志的行號
cat -n test.log |grep 地形  
  1. 得到"地形"關鍵字所在的行號是102行. 此時如果我想查看這個關鍵字前10行和后10行的日志:
cat -n test.log |tail -n +92|head -n 20

tail -n +92表示查詢92行之后的日志
head -n 20 則表示在前面的查詢結果里再查前20條記錄

或者直接用這個命令

cat test.log | grep -C 10  地形 

那么按日期怎么查呢? 通常我們非常需要查找指定時間端的日志

sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p'  test.log

特別說明:
上面的兩個日期必須是日志中打印出來的日志,否則無效.
關于日期打印,可以先 grep '2014-12-17 16:17:20' test.log 來確定日志中是否有該時間點

如果我們查找的日志很多,打印在屏幕上不方便查看, 有兩個方法:

(1)使用more和less命令, 如:

cat -n test.log |grep "地形" | less

這樣就分頁打印了,通過點擊空格鍵翻頁

(2)使用 >xxx.txt 將其保存到文件中,到時可以拉下這個文件分析.如:

cat -n test.log |grep "地形"  >xxx.txt

查找并分頁顯示

在test.log文件中的最后一萬行查找nick,并分頁顯示找到nick地方的上下5行

tail -n 10000 test.log | grep -C 5 nick| less
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容