一、指令碼思路
第一步就是重新命名記錄檔,不用擔心重新命名後nginx找不到記錄檔而丟失日誌。在你未重新開啟原名字的記錄檔前,nginx還是會向你重新命名的檔案寫日誌,linux是靠檔案描述符而不是檔案名稱定位檔案。
第二步向nginx主進程發送USR1訊號。
nginx主進程接到訊號後會從設定檔中讀取記錄檔名稱,重新開啟記錄檔(以設定檔中的日誌名稱命名),並以背景工作處理序的使用者作為記錄檔的所有者。
重新開啟記錄檔後,nginx主進程會關閉重名的記錄檔並通知背景工作處理序使用新開啟的記錄檔。
背景工作處理序立刻開啟新的記錄檔並關閉重名名的記錄檔。
然後你就可以處理舊的記錄檔了。
二、指令碼實現
nginx日誌按日期自動切割指令碼如下:
#nginx日誌切割指令碼#!/bin/bash#設定記錄檔存放目錄logs_path="/usr/local/nginx/logs/"#設定pid檔案pid_path="/usr/local/nginx/nginx.pid"#重新命名記錄檔mv ${logs_path}access.log ${logs_path}access_$(date -d "yesterday" +"%Y%m%d").log#向nginx主進程發訊號重新開啟日誌kill -USR1 `cat ${pid_path}`
實驗環境:
# cat /etc/redhat-release Red Hat Enterprise Linux Server release 5.3 (Tikanga)# /opt/nginx/nginx -vnginx version: nginx/1.6.2
代碼:
#!/bin/bash# ==============================================================================# chmod u+x /opt/nginx/cut_nginx_log.sh# crontab -e# 0 0 * * * /opt/nginx/cut_nginx_log.sh > /opt/nginx/logs/cut_nginx_log.log 2>&1# ==============================================================================LOGS_PATH="/opt/nginx/logs"ARCHIVE_YEAR=$(date -d "yesterday" "+%Y")ARCHIVE_MONTH=$(date -d "yesterday" "+%m")ARCHIVE_DATE=$(date -d "yesterday" "+%Y%m%d_%H%M%S")if [ -r /opt/nginx/nginx.pid ]; then mkdir -p "${LOGS_PATH}/${ARCHIVE_YEAR}/${ARCHIVE_MONTH}" mv "${LOGS_PATH}/access.log" "${LOGS_PATH}/${ARCHIVE_YEAR}/${ARCHIVE_MONTH}/access_${ARCHIVE_DATE}.log" kill -USR1 $(cat "/opt/nginx/nginx.pid") sleep 1 gzip "${LOGS_PATH}/${ARCHIVE_YEAR}/${ARCHIVE_MONTH}/access_${ARCHIVE_DATE}.log"else echo "Nginx might be down"fi# ==============================================================================# Clean up log files older than 100 days# ==============================================================================# Change HOUSEKEEPING=1 to enable clean upHOUSEKEEPING=0KEEP_DAYS=100if [ $HOUSEKEEPING == 1 ]; then if [ -d "${LOGS_PATH}" ]; then find "${LOGS_PATH}" -type f -name "access_*.log.gz" -mtime +${KEEP_DAYS} -exec rm -f {} \; fifi
參考:
http://wiki.nginx.org/LogRotation
儲存以上指令碼nginx_log.sh,並設定定時切割任務
三、定時工作
在crontab中設定作業
複製代碼 代碼如下:
0 0 * * * bash /usr/local/nginx/nginx_log.sh
這樣就每天的0點0分把nginx日誌重新命名為日期格式,並重建今天的新記錄檔。