Linux檢視日誌常用命令

y_keven發表於2015-08-19
1.檢視日誌常用命令
    tail:  
       -n  是顯示行號;相當於nl命令;例子如下:
            tail -100f test.log      實時監控100行日誌

            tail  -n  10  test.log   查詢日誌尾部最後10行的日誌;

            tail -n +10 test.log    查詢10行之後的所有日誌;

    head:  

        跟tail是相反的,tail是看後多少行日誌;例子如下:

            head -n 10  test.log   查詢日誌檔案中的頭10行日誌;

            head -n -10  test.log   查詢日誌檔案除了最後10行的其他所有日誌;

    cat: 

        tac是倒序檢視,是cat單詞反寫;例子如下:

            cat -n test.log |grep "debug"   查詢關鍵字的日誌


2. 應用場景一:按行號檢視---過濾出關鍵字附近的日誌

     1)cat -n test.log |grep "debug"  得到關鍵日誌的行號

     2)cat -n test.log |tail -n +92|head -n 20  選擇關鍵字所在的中間一行. 然後檢視這個關鍵字前10行和後10行的日誌:

            tail -n +92表示查詢92行之後的日誌

            head -n 20 則表示在前面的查詢結果裡再查前20條記錄


3. 應用場景二:根據日期查詢日誌

      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 "debug" |more     這樣就分頁列印了,通過點選空格鍵翻頁

    (2)使用 >xxx.txt 將其儲存到檔案中,到時可以拉下這個檔案分析

            如:cat -n test.log |grep "debug"  >debug.txt



相關文章