Nginx日志切割

由于 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  

你可能感兴趣的:(Nginx)