【Linux脚本】Nginx日志分割的shell脚本

avatar
作者
猴君
阅读量:0

环境:CentOS Linux release 7.6.1810 (Core)

编写一个Nginx日志分割的shell脚本,以实现只保留最近一周的日志文件。这个脚本将会分割access.log和error.log文件,并保留最近7天的日志。

#!/bin/bash  # Nginx日志目录 LOG_DIR="/usr/local/nginx/logs"  # 日志文件 ACCESS_LOG="$LOG_DIR/access.log" ERROR_LOG="$LOG_DIR/error.log"  # 获取当前日期 DATE=$(date +"%Y%m%d")  # 分割access.log if [ -f "$ACCESS_LOG" ]; then     mv "$ACCESS_LOG" "$ACCESS_LOG.$DATE"     touch "$ACCESS_LOG"     chmod 644 "$ACCESS_LOG" fi  # 分割error.log if [ -f "$ERROR_LOG" ]; then     mv "$ERROR_LOG" "$ERROR_LOG.$DATE"     touch "$ERROR_LOG"     chmod 644 "$ERROR_LOG" fi  # 向Nginx主进程发送USR1信号,重新打开日志文件 kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)  # 删除7天前的日志文件 find "$LOG_DIR" -name "*.log.*" -type f -mtime +7 -delete  # 可选:压缩超过一天的日志文件 find "$LOG_DIR" -name "*.log.*" -type f -mtime +0 -exec gzip -f {} \;  

这个脚本完成了以下任务:

  1. 定义了Nginx日志目录和日志文件的路径。
  2. 获取当前日期作为新日志文件的后缀。
  3. 分割access.log和error.log文件,将当前日志文件重命名为带日期后缀的文件。
  4. 创建新的空日志文件,并设置适当的权限。
  5. 向Nginx发送USR1信号,使其重新打开日志文件。
  6. 删除7天前的日志文件。
  7. 可选步骤:压缩超过一天的日志文件。

使用方法:

  1. 将这个脚本保存为文件,例如 nginx_log_rotate.sh
  2. 给脚本添加执行权限:chmod +x nginx_log_rotate.sh
  3. 您可以手动运行这个脚本,或者将它添加到crontab中每天自动运行。

要每天自动运行这个脚本,可以将以下行添加到root用户的crontab中:

0 0 * * * /path/to/nginx_log_rotate.sh 

这将使脚本每天午夜运行。

请注意,这个脚本假设Nginx的PID文件位于 /usr/local/nginx/logs/nginx.pid。如果您的Nginx配置中PID文件的位置不同,请相应地修改脚本。

此外,脚本中包含了一个可选的压缩步骤。如果您不需要压缩日志文件,可以删除或注释掉最后一行。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!