- 实现需求
本文实现的功能是在吗每天凌晨00:00把前一天的Nginx日志access.log重命名为access-xxxx-xx-xx.log格式,例如:access-2016-10-01.log,下面话不多说了,来看看详细的实现方法吧。
编写脚本:
我的nginx的logs存放目录:/usr/local/server/nginx/logs
所以我的脚本放在相同目录下面.
vim /usr/local/server/nginx/logs/cut_nginx_log.sh
- cut_nginx_log.sh内容如下:
#设置日志文件存放目录
LOG_PATH="/usr/local/server/nginx/logs"
#定义日期格式
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
#设置pid文件
PID=/usr/local/server/nginx/logs/nginx.pid
#重命名日志文件
mv $LOG_PATH/access.log $LOG_PATH/access.$RECORD_TIME.log
mv $LOG_PATH/error.log $LOG_PATH/error.$RECORD_TIME.log
#向nginx主进程发信号重新打开日志
kill -USR1 `cat $PID`
#自动删除7天前的nginx访问日志
find /usr/local/server/nginx/logs -name "access.2016-*.log" -type f -mtime +7 -exec rm {} \;
给脚本可执行权限
chmod 755 /usr/local/server/nginx/logs/cut_nginx_log.sh
- 运行脚本
./cut_nginx_log.sh
添加定时任务
crontab -e
# 每天0点执行一次
0 0 * * * /usr/local/server/nginx/logs/cut_nginx_log.sh