現有的日誌都會存在access.log文件中,但是隨着時間的推移,這個文件的內容會越來越多,體積會越來越大,不便於運維 人員查看,所以我們可以通過把這個大的日誌文件切割爲多份不 同的小文件作爲日誌,切割規則可以以天爲單位,如果每天有幾 百G或者幾個T的日誌的話,則可以按需以每半天或者每小時對曰志切割一下。
具體步驟如下:
1.創建一shell可執行文件:cut_my_log.sh,內容爲:
#!/bin/bash
LOG_PATH="/var/log/nginx/"
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
PID=/va r/run/nginx/nginx.pid
mv ${LOG_PATH}/access.log ${LOG_PATH}/access.${RECORD_TIME}.log
mv ${LOG_PATH}/error.log ${LOG_PATH}/error.${RECORD_TIME}.log
#進程發送信號,用於重開打開日誌文件
kill -USR1 'cat $PID'
- 爲cut_my_log.sh添加可執行的權限:
chmod +x cut_my_log.sh
- 測試日誌切割後的結果:
./cut_my_log.sh
4.安裝定時任務
yum install crontabs
5.crontab -e編輯並且添加一行新的任務
(定時任務使用cron表達式)
*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh
6.重啓定時任務:
service crond restart
- 常用定時任務命令:
命令 | 說明 |
---|---|
service crond start | 啓動服務 |
service crond stop | 關閉服務 |
service crond restart | 重啓服務 |
service crond reload | 重新載入配置 |
crontab -e | 編輯任務 |
crontab -1 | 查看任務列表 |