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.查看结果

可以发现,已经执行成功

相关推荐
zwjapple44 分钟前
docker一键部署前后端项目
docker
Lz__Heng3 小时前
如何在使用kickstart安装物理机操作系统的过程中核对服务器的SN
运维·服务器·自动化·kickstart
wanhengidc3 小时前
网站服务器出现异常的原因是什么?
运维·服务器
ZPC82105 小时前
Docker 挂载卷并保存为容器
docker·容器
feifeigo1235 小时前
Docker-compose 编排lnmp(dockerfile) 完成Wordpress
android·docker·容器
飞鹰服务器6 小时前
服务器带宽线路的区别(GIA、CN2、BGP、CMI等)
运维·服务器·带宽·cn2
普罗米修斯Aaron_Swartz7 小时前
WSL中ubuntu通过Windows带代理访问github
linux·运维·ubuntu
病树前头7 小时前
怎样将win11+ubuntu双系统的ubuntu从机械硬盘迁移至固态硬盘(1)
linux·运维·ubuntu
Hello.Reader9 小时前
Nginx stub_status 指南从启用到监控落地的全流程详解
运维·nginx
程序员的世界你不懂9 小时前
jenkins-jenkins简介
运维·jenkins