通過(guò)logrotate工具可以實(shí)現(xiàn)Nginx日志的輪轉(zhuǎn)策略。下面是一個(gè)基本的配置示例,展示了如何設(shè)置nginx日志輪轉(zhuǎn)策略:
-
創(chuàng)建logrotate配置文件:首先,創(chuàng)建一個(gè)新的logrotate配置文件,例如在/etc/logrotate.d/目錄下創(chuàng)建nginx文件。
sudo nano /etc/logrotate.d/nginx
-
配置logrotate:在這個(gè)文件中,添加以下內(nèi)容來(lái)配置Nginx日志的輪轉(zhuǎn)策略:
/var/log/nginx/*.log { daily missingok rotate 7 compress delaycompress notifempty create 0640 www-data adm sharedscripts postrotate if [ -f /var/run/nginx.pid ]; then kill -USR1 `cat /var/run/nginx.pid` fi endscript }
解釋這些選項(xiàng)的含義:
- daily: 日志每天輪轉(zhuǎn)一次。
- missingok: 如果日志文件丟失,不會(huì)報(bào)錯(cuò)。
- rotate 7: 保留7個(gè)輪轉(zhuǎn)后的日志文件。
- compress: 輪轉(zhuǎn)后的日志文件將被壓縮。
- delaycompress: 延遲壓縮,直到下一次輪轉(zhuǎn)。
- notifempty: 如果日志文件為空,不進(jìn)行輪轉(zhuǎn)。
- create 0640 www-data adm: 創(chuàng)建新的日志文件,權(quán)限為0640,屬主為www-data,屬組為adm。
- sharedscripts: 如果有多個(gè)日志文件匹配,只執(zhí)行一次postrotate腳本。
- postrotate: 在輪轉(zhuǎn)日志后執(zhí)行的腳本。這里使用kill -USR1命令通知Nginx重新打開(kāi)日志文件。
-
測(cè)試配置:保存并關(guān)閉文件后,可以使用以下命令測(cè)試logrotate配置是否正確:
sudo logrotate -f /etc/logrotate.d/nginx
這個(gè)命令會(huì)強(qiáng)制輪轉(zhuǎn)Nginx日志,并輸出詳細(xì)的日志信息。
-
自動(dòng)輪轉(zhuǎn):logrotate通常會(huì)每天自動(dòng)運(yùn)行一次,檢查并輪轉(zhuǎn)符合條件的日志文件。你可以通過(guò)查看/var/lib/logrotate/status文件來(lái)確認(rèn)logrotate的狀態(tài)和歷史記錄。
通過(guò)以上步驟,你可以成功配置Nginx日志的輪轉(zhuǎn)策略,確保日志文件不會(huì)無(wú)限增長(zhǎng),同時(shí)保留一定數(shù)量的輪轉(zhuǎn)日志文件以便后續(xù)分析。