Nginx 日志切割 | Eddie'Blog
Nginx 日志切割

Nginx 日志切割

eddie 302 2021-06-22

目录

(一)Nginx 日志切割 - 手动版

  1. 创建一个Shell的可执行脚本:cut_nginx_log.sh,内容为:
#!/bin/bash
LOG_PATH="/var/log/nginx"
#RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d)
#PID=/var/run/nginx/nginx.pid
PID=/var/run/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`

通过 nginx -V 查看原路径

  1. 为 cut_nginx_log.sh 添加可执行的权限:
chmod +x cut_nginx_log.sh
  1. 运行切割脚本:
./cut_nginx_log.sh

(二)Nginx 日志切割 - 定时版

使用定时任务

  1. 安装定时任务依赖
yum install crontabs
  1. crontab -e 编辑并且添加一行新的任务
*/1 * * * * /usr/local/nginx/sbin/cut_nginx_log.sh
  1. 重启定时任务
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 * * *

参考

nginx访问日志(access_log)