1. 程式人生 > >Linux查看日誌方法總結(1)

Linux查看日誌方法總結(1)

關鍵字 http grep 定時 abd cab 我們 做的 ext

註:日誌文件為:test.log

1.tail -f test.log

查看當前打印的日誌(平時就知道這方法!打印出的長度有限制。)

以下為網上搜集的:

2.先必須了解兩個最基本的命令:

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

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

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

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

    技術分享圖片
  2. 場景1: 按行號查看---過濾出關鍵字附近的日誌

    因為通常時候我們用grep拿到的日誌很少,我們需要查看附近的日誌.

    我是這樣做的,首先: cat -n test.log |grep "地形" 得到關鍵日誌的行號

    技術分享圖片
  3. <3>得到"地形"關鍵字所在的行號是102行. 此時如果我想查看這個關鍵字前10行和後10行的日誌:

    cat -n test.log |tail -n +92|head -n 20

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

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

    技術分享圖片
  4. 場景2:那麽按日期怎麽查呢? 通常我們非常需要查找指定時間端的日誌

    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 這樣就分頁打印了,通過點擊空格鍵翻頁

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

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

技術分享圖片

Linux查看日誌方法總結(1)