日志文件切割要求
由于 Nginx的日志都是写在一个文件当中,因此,我们需要每天零点的时候将前一天的日志存为另外一个文件,这里我们就将 Nginx 位于 logs 目录中的 access.log、error.log存为 access_[yyyy-MM-dd].log\error_[yyyy-MM-dd].log 的文件。
1、shell代码:
#!/bin/bash
## 零点执行该脚本
## Nginx 日志文件所在的目录
LOGS_PATH=/usr/local/nginx/logs
## 获取昨天的 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 $(cat /var/run/nginx.pid)
文件名(自定义),我把它放在/usr/local/sbin/cat-log.sh
使用find命令查找你的nginx.pid文件在哪个位置,然后放入进去。
要赋予此shell文件权限为可执行。
首先需要确定你的服务器有没有安装crontab的服务,输入crontab -e命令,有反应就安装了。
如果没有安装,运行yum install vixie-cron 一键安装。
输入crontab -e命令,输入下面的内容:
00 00 * * * /bin/bash /usr/local/nginx/sbin/cut-log.sh
1)、00 00意思为00分00点,也就是凌晨0点,后面“ * * * ”为“ 日 月 年 ”无需定义
2)、” /usr/local/nginx/sbin/cut-log.sh “为你的shell的路径,也就是说每天零点的时候执行这个shell。
OK !大功告成,每天的0时就会自动完成日志的切割并存在相应的以日期命名的目录中。
然后测试。把时间改为离你现在最近的时间。