由于 Nginx 的日志都是写在一个文件当中的,因此,我们需要每天零点将前一天的日志存为另外一个文件,这里我们就将 Nginx 位于 logs 目录中的 access.log 存为 access_[yyyy-MM-dd].log 的文件。其实 logs 目录中还有个 error.log 的错误日志文件,这个文件也需要每天切割一个,在这里就说 access.log 了,error.log 的切割方法类似。
#!/bin/bash
# 零点执行该脚本
#Nginx 日志文件所在的目录
LOGS_PATH=/usr/local/nginx/logs
PID=`cat /usr/local/nginx/logs/nginx.pid`
#获取昨天的 yyyy-MM-dd
YESTERDAY=$(date -d
"yesterday"
+%Y-%m-%d)
#移动文件
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log
#向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件
kill -USR1 $PID
使用 crontab -e 新增一个定时任务,在其中增加执行这个脚本:
0
0
* * * /bin/bash /usr/local/nginx/sbin/cut-log.sh