2002-nginx日誌切割

一、手動切割

Nginx 日誌切割-手動

現有的日誌都會存在 access.log
文件中,但是隨着時間的推移,這個文件的內容會越來越多,體積會越來越大,不便於運維人員查看,所以我們可以通過把這個大的日誌文件切割爲多份不同的小文件作爲日誌,切割規則可以以天爲單位,如果每天有幾百G或者幾個T的日誌的話,則可以按需以每半天或者每小時對日誌切割一下。

具體步驟如下:

創建一個shell可執行文件:cut_my_log.sh,內容爲:

#!/bin/bash
LOG_PATH="/var/log/nginx/"
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
PID=/var/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

#向Nginx主進程發送信號,用於重新打開日誌文件
kill -USR1 `cat $PID`

爲cut_my_log.sh添加可執行的權限:

chmod +x cut_my_log.sh

測試日誌切割後的結果:

./cut_my_log.sh

二、自動切割-定時

定時任務【本地虛擬機中,centos6或7,自帶crontabs】

使用定時任務
安裝定時任務:

yum install crontabs

crontab -e 編輯並且添加一行新的任務:

*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh

重啓定時任務:

service crond restart

附:常用定時任務命令:

service crond start         //啓動服務
service crond stop          //關閉服務
service crond restart       //重啓服務
service crond reload        //重新載入配置
crontab -e                  // 編輯任務
crontab -l                  // 查看任務列表

定時任務表達式:
Cron表達式是,分爲5或6個域,每個域代表一個含義,如下所示:
在這裏插入圖片描述

常用表達式:

每分鐘執行:

*/1 * * * *

每日凌晨(每天晚上23:59)執行:

59 23 * * *

每日凌晨1點執行:

0 1 * * *

參考文獻:

每天定時爲數據庫備份:https://www.cnblogs.com/leechenxiang/p/7110382.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章