1. 程式人生 > >那些年我們用過的檢視日誌的命令

那些年我們用過的檢視日誌的命令

我們經常需要在日誌中搜索日誌,找程式碼中的問題,有時候我們需要精確的找到某一行或某個時間的日誌,下面我們來看看都怎麼用命令來搜尋相關日誌。
cat -n test.log日誌是有行號的, cat test.log 日誌沒有行號
tail -n 10 test.log 查詢日誌尾部最後10行的日誌;
tail -n +10 test.log 查詢10行之後的所有日誌;
head -n 10 test.log 查詢日誌檔案中的頭10行日誌;
head -n -10 test.log 查詢日誌檔案除了最後10行的其他所有日誌;

一、按關鍵字查詢,輸出當前這個日誌的前後幾行(顯示關鍵字上下文)
cat catalina.out| grep -C 5 ‘失敗’ #顯示file檔案裡匹配foo字串那行以及上下5行
cat catalina.out | grep -B 5 ‘失敗’ #顯示foo及前5行
cat catalina.out | grep -A 5 ‘失敗’ 顯示foo及後5行
綜合例如:
cat -n nohup.out | grep -A 25 “人身險報案領款賬戶資訊查詢-前臺請求” | tail -n 100
//關鍵字”人身險報案領款賬戶資訊查詢-前臺請求”的這個關鍵字後25行,然後以這個搜最後100行
按行號檢視—過濾出關鍵字附近的日誌
因為通常時候我們用grep拿到的日誌很少,我們需要檢視附近的日誌.
我是這樣做的,首先: cat -n test.log |grep “地形” 得到關鍵日誌的行號
得到"地形"關鍵字所在的行號是102行. 此時如果我想檢視這個關鍵字前10行和後10行的日誌:
cat -n test.log |tail -n +92|head -n 20
tail -n +92表示查詢92行之後的日誌
head -n 20 則表示在前面的查詢結果裡再查前20條記錄
注意:使用這個命令的時候不能千萬不能加grep條件

二、按日期怎麼查呢? 通常我們非常需要查詢指定時間端的日誌
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 來確定日誌中是否有該時間點,以確保第4步可以拿到日誌,存在這個時間的日誌就會打印出來
這個根據時間段查詢日誌是非常有用的命令.
如果我們查詢的日誌很多,列印在螢幕上不方便檢視, 有兩個方法:

(1)使用more和less命令, 如: cat -n test.log |grep “地形” |more 這樣就分頁列印了,通過點選空格鍵翻頁,More或者less最後要按q鍵退出

(2)使用 >xxx.txt 將其儲存到檔案中,到時可以拉下這個檔案分析.如:
cat -n test.log |grep “地形” >xxx.txt