首頁 > 軟體

linux查詢紀錄檔技巧

2019-12-18 04:14:29

對於從事web開發的人員來說.伺服器上的紀錄檔多如牛毛,如何快速從中找出所需資訊非常重要,以下是我在工作中用到的查詢紀錄檔的簡單命令,希望能對您有所幫助:


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

特別說明:上面的兩個日期必須是紀錄檔中列印出來的紀錄檔,否則無效.


5

關於日期列印,可以先 grep '2014-12-17 16:17:20' test.log 來確定紀錄檔中是否有該時間點,以確保第4步可以拿到紀錄檔這個根據時間段查詢紀錄檔是非常有用的命令.

6

如果我們查詢的紀錄檔很多,列印在螢幕上不方便檢視, 有兩個方法:

(1)使用more和less命令, 如: cat -n test.log |grep "地形" |more     這樣就分頁列印了,通過點選空格鍵翻頁

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

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


7

這幾個紀錄檔檢視方法應該可以滿足日常需求了.

IT145.com E-mail:sddin#qq.com