注意:首先要先保证nginx处于启动的状态!!
然后写我们脚本文件cut_my_log.sh:
#!/bin/bash
LOG_PATH="/var/log/nginx"
RECORD_TIME=$(date -d "now" +%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`
这边我是把写好的脚本文件放在了 /usr/local/nginx/sbin 目录下:
手动方式:
执行我们写好的脚本文件~
如果有出现权限不够的情况,记得先给脚本文件增加可执行权限:
添加可执行权限:
然后执行脚本文件:
执行完后可以发现我们日志文件已经切割完成了:
定时方式
1.先安装定时任务依赖:
yum install crontabs
2.终端输入命令:crontab -e 添加一行新的定时任务(每分钟执行一次日志切割):
*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh
添加完记得输入 :wq 保存并退出。
然后输入crontab -l 命令能看到我们刚才添加的定时任务:
3.添加完后我们要重新启动下我们的定时任务:
service crond restart
可以看到我们的日志定时每分钟切割一次:
附录
常用定时任务命令:
命令 | 解释 |
---|---|
service crond start | 启动服务 |
service crond stop | 关闭服务 |
service crond restart | 重启服务 |
service crond reload | 重新载入配置 |
crontab -e | 编辑任务 |
crontab -l | 查看任务列表 |
Cron表达式:
分 | 时 | 日 | 月 | 星期几 | 年(可选) | |
---|---|---|---|---|---|---|
取值范围 | 0-59 | 0-23 | 1-31 | 1-12 | 1-7 | 2019/2020/2021/… |
常用表达式:
- 每分钟执行
*/1 * * * *
- 每天晚上23:59执行
59 23 * * *
- 每日凌晨1点执行
0 1 * * *