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 // 查看任务列表
posted @ 2020-05-06 13:36  范特西-  阅读(116)  评论(0)    收藏  举报