nginx日誌切割shell指令碼_linux shell

來源:互聯網
上載者:User

一、指令碼思路

第一步就是重新命名記錄檔,不用擔心重新命名後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日誌重新命名為日期格式,並重建今天的新記錄檔。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.