zl程序教程

您现在的位置是:首页 >  工具

当前栏目

Nginx日志切割 手动+定时两种方式 非常详细

日志Nginx 方式 详细 两种 定时 手动 非常
2023-09-11 14:21:24 时间

注意:首先要先保证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-590-231-311-121-72019/2020/2021/…

常用表达式:

  • 每分钟执行
 */1 * * * *
  • 每天晚上23:59执行
 59 23 * * *
  • 每日凌晨1点执行
0 1 * * *