如何定时切割nginx日志?
Posted 皮卡丘的猫
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何定时切割nginx日志?相关的知识,希望对你有一定的参考价值。
引言:大家好,我是热爱coding,崇尚开源,乐于分享的【皮卡丘的猫】
nginx日志文件默认有两个,一个是access.log,一个是error.log,随着项目的运行, 两个日志文件会变得越来越大,后期排查错误就不好定位,为了解决这个问题,每天凌晨定时将日志切割。
step1:在/usr/local/nginx/sbin 目录下编写定时切割脚本
vim cut_my_log.sh
#!/bin/bash
LOG_PATH="/var/log/nginx/"
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
PID=/var/run/nginx/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`
赋予执行权限
chmod 755 cut_my_log.sh
step2:安装定时任务
yum install crontabs
step3:添加一项定时任务执行 crontab -e
59 23 * * * /usr/local/nginx/sbin/cut_my_log.sh
step4:重启定时任务
service crond restart
-
附:常用定时任务命令:
service crond start //启动服务
service crond stop //关闭服务
service crond restart //重启服务
service crond reload //重新载入配置
crontab -e // 编辑任务
crontab -l // 查看任务列表
定时任务表达式:
Cron表达式是,分为5或6个域,每个域代表一个含义,如下所示:
分 | 时 | 日 | 月 | 星期几 | 年(可选) | |
取值范围 | 0-59 | 0-23 | 1-31 | 1-12 | 1-7 | 2019/2020/2021/… |
常用表达式:
-
每分钟执行:
*/1 * * * *
-
每日凌晨(每天晚上23:59)执行:
59 23 * * *
-
每日凌晨1点执行:
0 1 * * *
以上是关于如何定时切割nginx日志?的主要内容,如果未能解决你的问题,请参考以下文章