Nginx的定时任务切割

2020-11-20  本文已影响0人  小狐憨憨

Nginx的定时任务切割

语雀Q群:763215167

现有的日志都会存在access.log文件中,但是随着时间的推移,这个文件的内容会越来越多,体积会越来越大,不便于查看,所以我们可以通过把这个大的日志文件切割为多份不 同的小文件作为日志,切割规则可以以天为单位,如果每天有几 百G或者几个T的日志的话,则可以按需以每半天或者每小时对曰志切割一下

具体步骤如下
1.创建一shell可执行文件:xiaohu.sh

#!/bin/bash
#nignx的日志文件路径
LOG_PATH="/usr/local/nginx/logs/"
#切分时间点%Y-%m-%d+%H:%M执行到哪就标记到哪 年 月 天 时 分 
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d)
#nginx的pid
PID=/usr/local/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 
#进程发送信号,用于重开打开日志文件
kill -USR1 'cat $PID'

为脚本文件添加执行权限

chmod +x xiaohu.sh

安装定时任务模块

yum install crontabs

crontab -e 编辑一行任务

#corn表达式 + 执行的脚本路径 (23点59分执行)
59 23 * * * /usr/local/nginx/sbin/cut_my_log.sh

重启定时任务

service crond restart 

//可以查看定时任务列表
crontab -l

//关闭定时任务
service crond stop
上一篇下一篇

猜你喜欢

热点阅读