Nginx--手写脚本压缩和切分日志(也适用于docker)

原文网址:Nginx--手写脚本压缩和切分日志(也适用于docker)_IT利刃出鞘的博客-CSDN博客

简介

本文介绍nginx如何手写脚本压缩和切分日志。

1.创建切分日志的脚本

创建脚本文件:/work/tmp/nginx-log_sh(后边要用run-parts去运行,脚本名中不能带.)

内容如下:

法1:每小时执行

bash 复制代码
#!/bin/bash

# 轮转的时间单位
rotateUnit="1 hour"
# 日志位置
logPath=/work/middle/nginx/logs/
# 文件存活天数(这些天之前的文件会被删掉)
oldFileTtl=20

# 当前时间
nowTime=$(date +"%Y%m%d %H")
# 上一段时间
preTime=$(date -d "$nowTime -$rotateUnit" +"%Y%m%d %H")
# 上一段时间对应的文件名后缀
preTimeFileSuffix=$(date -d "$nowTime -$rotateUnit" +"%Y%m%d_%H")
# 上一段日期对应的目录
preDatePath=$(date -d "$preTime" +"%F")

if [ ! -d "$logPath" ];
then
    exit 1
fi

cd $logPath

if [ ! -d "$preDatePath" ];
then
    mkdir -p "$preDatePath"
fi

# 将access.log和error.log移到日期文件夹内
mv *.log $preDatePath

# 通知Nginx,让它重新生成一份access.log和error.log
docker exec nginx1.23.3 /bin/bash -c \
    "if [ -f /run/nginx.pid ]; 
     then kill -USR1 `docker exec nginx1.23.3 cat /run/nginx.pid`; 
          echo 日志打包完毕; fi"
    # 如果是非docker方式启动nginx,则这样写
    # [ -f /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid`

# 压缩文件
pushd $preDatePath
tar czf $preTimeFileSuffix.tar.gz *.log
rm *.log -f
popd

# 删除指定时间之前的日志
find ./ -type d -mtime +$oldFileTtl | xargs rm -rf
find ./ -type d -mtime +2 -empty -delete 

备注

如果需要指定时区,可以这么写:

bash 复制代码
#!/bin/bash

getNowTime()
{
    TZ='Asia/Shanghai' date "+%Y%m%d_%H%M"
}
nowTime=$(getNowTime)

法2:每天执行

bash 复制代码
#!/bin/bash

# 轮转的时间单位
rotateUnit="1 day"
# 日志位置
logPath=/work/middle/nginx/logs/
# 文件存活天数(这些天之前的文件会被删掉)
oldFileTtl=20

# 当前时间
nowTime=$(date +"%Y%m%d")
# 上一段时间
preTime=$(date -d "$nowTime -$rotateUnit" +"%Y%m%d")
# 上一段时间对应的文件名后缀
preTimeFileSuffix=$(date -d "$nowTime -$rotateUnit" +"%Y%m%d")
# 上一段日期对应的目录
preDatePath=$(date -d "$preTime" +"%F")

if [ ! -d "$logPath" ];
then
    exit 1
fi

cd $logPath

if [ ! -d "$preDatePath" ];
then
    mkdir "$preDatePath"
fi

# 将access.log和error.log移到日期文件夹内
mv *.log $preDatePath

# 通知Nginx,让它重新生成一份access.log和error.log
docker exec nginx1.23.3 /bin/bash -c \
    "if [ -f /run/nginx.pid ]; 
     then kill -USR1 `docker exec nginx1.23.3 cat /run/nginx.pid`; 
          echo 日志打包完毕; fi"
    # 如果是非docker方式启动nginx,则这样写
    # [ -f /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid`

# 压缩文件
pushd $preDatePath
tar czf $preTimeFileSuffix.tar.gz *.log
rm *.log -f
popd

# 删除指定时间之前的日志
find ./ -type d -mtime +$oldFileTtl | xargs rm -rf
find ./ -type d -mtime +2 -empty -delete 

2.创建定时任务

命令

复制代码
sudo crontab -e

添加如下内容(本处我用两分钟执行一次来测试)

bash 复制代码
*/2 * * * * run-parts /work/tmp &>>/work/tmp/log.txt

实际应该这样写每小时执行一次:

bash 复制代码
​1 * * * * run-parts /work/tmp &>>/work/tmp/log.txt

编辑完保存后,会自动生效。如下图所示:

3.查看任务是否执行

如图所示,已经执行

4.查看结果

可以发现,已经执行成功

相关推荐
w***Q3502 小时前
Git工作流自动化
运维·git·自动化
xu_yule5 小时前
Linux_12(进程信号)内核态和用户态+处理信号+不可重入函数+volatile
linux·运维·服务器
虾..5 小时前
Linux 环境变量&&进程优先级
linux·运维·服务器
小雪_Snow6 小时前
CentOS 7 测试 docker 镜像源
docker·centos
zhuyasen7 小时前
Go Web 开发利器:如何让你的 Gin 服务拥有 Nginx 般的静态文件处理能力?
nginx·go·gin
achi0107 小时前
Ubuntu 24.04 LTS 下 Vue 3 开发环境搭建与生产部署完整指南
nginx·node·nvm·vue 3·ubuntu 24·开发环境搭建·国内镜像仓库
数据库学啊7 小时前
团队小希望运维简单,时序数据库选型有什么推荐?
运维·数据库·时序数据库
霍格沃兹软件测试开发7 小时前
Playwright MCP浏览器自动化指南:让AI精准理解你的命令
运维·人工智能·自动化
郝学胜-神的一滴8 小时前
Linux命名管道:创建与原理详解
linux·运维·服务器·开发语言·c++·程序人生·个人开发
wanhengidc8 小时前
云手机性能如何?
运维·服务器·科技·智能手机·云计算