使用Bash腳本和Logrotate實現(xiàn)Nginx日志切割的方法
Nginx是一個廣泛使用的高性能Web服務(wù)器,它能夠處理大量的并發(fā)連接,但同時也會生成大量的日志文件。為了有效管理這些日志文件并確保系統(tǒng)的正常運行,我們需要定期對Nginx的日志文件進行切割和歸檔。本文將介紹如何使用Bash腳本和Logrotate來實現(xiàn)Nginx日志的切割。
Bash腳本實現(xiàn)
假設(shè)Nginx的訪問日志文件位于/var/log/nginx/access.log
#!/bin/bash LOG_FILE="/var/log/nginx/access.log" ARCHIVE_DIR="/var/log/nginx/archive" # 判斷歸檔目錄是否存在,如果不存在則創(chuàng)建 if [ ! -d "$ARCHIVE_DIR" ]; then mkdir -p $ARCHIVE_DIR fi # 使用gzip壓縮日志文件并移動到歸檔目錄 DATE=$(date +"%Y%m%d%H%M%S") mv $LOG_FILE "$ARCHIVE_DIR/access_$DATE.log" gzip "$ARCHIVE_DIR/access_$DATE.log" # 重新打開日志文件,以便Nginx繼續(xù)寫入新的日志 kill -USR1 $(cat /var/run/nginx.pid)
以上腳本的功能包括:
- 檢查歸檔目錄是否存在,如果不存在則創(chuàng)建。
- 將當(dāng)前的訪問日志文件移動到歸檔目錄,并使用gzip進行壓縮。
- 向Nginx發(fā)送USR1信號,以便重新打開日志文件,使Nginx能夠繼續(xù)寫入新的日志。
Logrotate實現(xiàn)
Logrotate是一個Linux系統(tǒng)上用來管理日志文件的工具,它可以定期輪轉(zhuǎn)日志文件、壓縮舊的日志文件以及刪除過期的日志文件。Logrotate通過配置文件定義輪轉(zhuǎn)規(guī)則,并由系統(tǒng)的cron任務(wù)周期性地執(zhí)行。
假設(shè)Nginx的有兩個訪問日志文件分為位于
- /apps/openresty/nginx/logs/head/access.log
- /apps/openresty/nginx/logs/domain/access.log。
在/etc/logrotate.d目錄下創(chuàng)建一個名為nginx的文件,并添加以下內(nèi)容
/apps/openresty/nginx/logs/head/access.log /apps/openresty/nginx/logs/domain/access.log { daily # 每天切割 missingok # 忽略錯誤 rotate 7 # 最多保留多少個存檔 compress # 切割后且壓縮 delaycompress # 延遲壓縮動作在下一次切割 notifempty # 日志為空就不切割 create 640 qhdrsj qhdrsj # 切割的文件權(quán)限 sharedscripts # 共享腳本,結(jié)果為空 postrotate # 收尾動作,重新生成nginx日志 if [ -f /apps/openresty/nginx/logs/domain/nginx.pid ]; then kill -USR1 `cat /apps/openresty/nginx/logs/domain/nginx.pid` fi if [ -f /apps/openresty/nginx/logs/head/nginx.pid ]; then kill -USR1 `cat /apps/openresty/nginx/logs/head/nginx.pid` fi endscript # 結(jié)束動作 }
以上配置的含義如下:
- daily:每天輪轉(zhuǎn)一次日志。
- missingok:如果日志文件不存在,則不報錯。
- rotate 7:保留最近的7個歸檔文件。
- compress:使用gzip壓縮輪轉(zhuǎn)后的日志文件。
- delaycompress:延遲壓縮,直到下一次輪轉(zhuǎn)時才壓縮上一次的日志文件。
- notifempty:如果日志文件為空,則不輪轉(zhuǎn)。
- create:設(shè)置新創(chuàng)建的日志文件的權(quán)限和屬主。
- sharedscripts:在所有日志文件輪轉(zhuǎn)之后執(zhí)行一次腳本。
- postrotate和endscript:在輪轉(zhuǎn)后執(zhí)行的內(nèi)容。
到此這篇關(guān)于使用Bash腳本和Logrotate實現(xiàn)Nginx日志切割的文章就介紹到這了,更多相關(guān)Nginx日志切割內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Ubuntu使用nginx搭建webdav文件服務(wù)器的詳細過程
今天通過本文給大家分享Ubuntu使用nginx搭建webdav文件服務(wù)器的詳細過程,在這小編提示大家在安裝nginx時需要先安裝nginx-full,具體安裝方法跟隨小編一起通過本文學(xué)習(xí)下吧2021-05-05記一次nginx配置不當(dāng)引發(fā)的499與failover 機制失效問題
近期在非高峰期也存在499超過告警閾值的偶發(fā)情況,多的時候一天幾次,少的時候則幾天一次,持續(xù)一般也就數(shù)分鐘,經(jīng)過和小伙伴的共同探究,最后發(fā)現(xiàn)之前對于499是客戶端主動斷開因而和服務(wù)端關(guān)系不大的想當(dāng)然認知是錯誤的,這里記錄一下2023-05-05詳解Nginx服務(wù)器的配置中開啟文件Gzip壓縮的方法
這篇文章主要介紹了Nginx服務(wù)器的配置中開啟文件Gzip壓縮的方法,可以對CSS和JavaScript以及各種圖片等web傳輸?shù)奈募M行壓縮,需要的朋友可以參考下2016-01-01