Nginx日志分割
Nginx默认日志都统一放在一个文件,这样当出现问题排查错误是不好排查的,所以我们对日志进行一个分割,比如针对每天生成一个日志文件
在sbin路径下创建一个
cut_my_log.sh脚本
#!/bin/bash
LOG_PATH="/usr/local/nginx/logs" #log的路径
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M) #指定时间 ,这里是按分
PID=/usr/local/nginx/logs/nginx.pid #指定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`
赋予
cut_my_log.sh脚本执行权限
chmod +x cut_my_log.sh
执行脚本
./cut_my_log.sh
然后回到logs目录,会看到文件access.log和error.log已经分为日期格式
access.2020-05-05+13:12.log
当需要分割的时候执行脚本就可以了,但是它不会自动分割的
接下来通过定时任务来实现自动分割
安装定时任务
yum install crontabs
查看任务
crontab -l
添加任务
执行该命令,会出现vim编辑页
crontab -e
然后添加以下内容
*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh
*/1 * * * * : 表示定时表达式,每分钟执行一次任务
/usr/local/nginx/sbin/cut_my_log.sh :之前写好的日志分割脚本
常用定时表达式
每分钟执行:
*/1 * * * *
每日凌晨(每天晚上23:59)执行:
59 23 * * *
每日凌晨1点执行:
0 1 * * *
定时任务添加好了以后,开始执行任务
service crond restart
常用命令
service crond start //启动服务
service crond stop //关闭服务
service crond restart //重启服务
service crond reload //重新载入配置
crontab -e // 编辑任务
crontab -l // 查看任务列表

浙公网安备 33010602011771号