docker部署nginx下日志自动切割方法实现

 更新时间:2024年10月17日 10:55:25   作者:南山老沙  
部署Nginx在Docker中时,其日志文件默认不会自动切割,与非Docker环境有所不同,本文介绍了三种日志切割方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

nginx采用docker部署,简单方便,但出现一个问题,就是日志没有自动切割,导致access.log 无限增大。如果非docker安装,则nginx的日志默认有切割的,那docker为何没有呢,最后发现,nginx容器里面没有 logrotate 服务(logrotate: command not found)

服务器环境:centos 7
nginx的docker运行命令:

docker run -d --name nginx --restart always --net host -v /opt/common/nginx/nginx.conf:/etc/nginx/nginx.conf -v /opt/common/nginx/html:/usr/share/nginx/html -v /opt/common/nginx/logs:/var/log/nginx -v /opt/common/nginx/conf.d:/etc/nginx/conf.d -e TZ="Asia/Shanghai" nginx:1.24.0

其中服务器本地日志映射目录是 /opt/common/nginx/logs

以下搜集了几种日志切割方式:

  • 1 nginx配置map日期
  • 2 脚本切割
  • 3 配置 logrotate

1 nginx配置map日期

在 nginx/conf.d 目录下,新建 logdate.conf 文件(nginx重启会自动加载的)
内容是:

map $time_iso8601 $logdate {
    default 'date-not-found';
    '~^(?<ymd>\d{4}-\d{2}-\d{2})' $ymd;
}

然后在 nginx.conf 的日志配置如下:

access_log  /var/log/nginx/access-$logdate.log  main;

原来的默认配置是:

access_log /var/log/nginx/access.log main;

这时到了第二天就会自动生成新的log文件
注意:映射 出来的存log的文件夹logs需要配一下权限,因为nginx要创建文件需要权限

例如:赋给nginx权限

chown -R nginx:nginx logs

生成之后,文件长这样:

在这里插入图片描述

该方法是按每天归整,缺点是每次打日志会走map一次日期,会牺牲一点点性能,此外,定期清理日志,需要再额外写个清理脚本(只保留N天,腾出存储空间),切割日志目的之一就是为了方便清理日志

2 脚本切割

该方法是写个脚本,定时凌晨12点将日志切割归档,这个方法相对比较简单

#!/bin/bash
LOGS_PATH=$1
DAYS=$2
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
#按天切割日志
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
#向 Nginx 主进程发送 USR1 信号,重新打开日志文件,否则会继续往mv后的文件写内容,导致切割失败.
kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`
#删除配置的N天前的日志
cd ${LOGS_PATH}
find . -mtime +${DAYS} -name "*20[1-9][3-9]*" | xargs rm -f
exit 0

将该脚本保存到 cut_nginx_log.sh,找个地方放,例如放在
/opt/common/nginx/logs/cut_nginx_log.sh

给该文件增加执行权限:
chmod +x /opt/common/nginx/logs/cut_nginx_log.sh

然后编辑定时任务:
crontab -e

编辑写入:

01 00 * * * /opt/common/nginx/logs/cut_nginx_log.sh /opt/common/nginx/logs/ 120

这个定时任务是,每天凌晨01秒,开始执行该脚本,脚本第一个参数 /opt/common/nginx/logs/ 表示日志的目录,第二个参数120表示日志保留120天,即清理120天之前的日志

这个方法是切割与定期清理一起,比较简单方便

3 配置 logrotate

既然nginx容器里面的 logrotate 服务不可用,那么就利用docker宿主机的 logrotate 服务,这个服务是 centos7 默认安装的,即利用服务器本地的 logrotate。
将以下脚本保存在 /etc/logrotate.d/nginx (vi /etc/logrotate.d/nginx,然后将以下脚本复制进去)

/opt/common/nginx/logs/*.log {
        daily
        missingok
        rotate 52
        compress
        delaycompress
        notifempty
        create 640 nginx adm
        sharedscripts
        postrotate
                kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`
        endscript
}

然后添加定时任务:

echo “59 23 * * * /usr/sbin/logrotate -f /etc/logrotate.d/nginx >/dev/null 2>&1” > /etc/crontab

或者执行 crontab -e ,然后将以下编辑写入

59 23 * * * /usr/sbin/logrotate -f /etc/logrotate.d/nginx >/dev/null 2>&1

这个定时任务是,每天23:59 开始切割,并做压缩
结果是:

在这里插入图片描述

此外,error.log 也会切割,其中脚本具体参数意义在此不做详述

最后总结:

以上三种,脚本方式是比较简单,可根据情况进行配置,选其一即可,更多相关docker nginx日志自动切割内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Docker 打包python的命令详解

    Docker 打包python的命令详解

    最近用Python写了一段爬虫程序,为了隔离其运行环境,易于分发,把项目打包成Docker镜像,下面给大家简单介绍下具体命令写法
    2016-12-12
  • 解决docker run 或者 docker restart 启动镜像就自动退出

    解决docker run 或者 docker restart 启动镜像就自动退出

    这篇文章主要介绍了解决docker run 或者 docker restart 启动镜像就自动退出的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • 在Docker中安装OnlyOffice的详细过程记录

    在Docker中安装OnlyOffice的详细过程记录

    OnlyOffice是一款免费且开源的Office协作办公套件,支持桌面端和移动端等多平台,下面这篇文章主要给大家介绍了关于如何在Docker中安装OnlyOffice的详细过程记录,需要的朋友可以参考下
    2024-01-01
  • 如何解决docker镜像在不同cpu架构上运行容器报错问题

    如何解决docker镜像在不同cpu架构上运行容器报错问题

    文章主要介绍了如何查看本地Docker镜像的CPU架构类型,并提供了解决x86镜像无法在ARM CPU上运行的问题的方法,通过在Dockerfile中使用`--platform`参数指定CPU架构,可以在构建镜像时选择正确的版本,从而解决架构不匹配的问题
    2024-12-12
  • docker kubernetes dashboard安装部署详细介绍

    docker kubernetes dashboard安装部署详细介绍

    这篇文章主要介绍了docker kubernetes dashboard安装部署详细介绍的相关资料,需要的朋友可以参考下
    2016-10-10
  • docker安装,yum安装失败解决方案,阿里云镜像安装过程

    docker安装,yum安装失败解决方案,阿里云镜像安装过程

    在配置Yum源遇到问题时,尝试使用阿里云镜像可以有效解决,本文详细介绍了如何配置阿里云源及安装Docker的步骤,首先,若Yum源配置出错,建议更换为阿里云镜像;其次,详述了安装Docker的具体命令,包括启用阿里云源和安装过程中的选择提示
    2024-11-11
  • docker部署MinIO对象存储的实践指南

    docker部署MinIO对象存储的实践指南

    MinIO是一款高性能的开源对象存储服务器,兼容Amazon S3 API,适用于存储非结构化数据,本文主要为大家介绍了docker部署MinIO对象存储的详细步骤,需要的可以了解下
    2025-06-06
  • 如何在Docker容器内外互相拷贝数据

    如何在Docker容器内外互相拷贝数据

    本篇文章主要介绍了如何在Docker容器内外互相拷贝数据,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • 浅谈Docker镜像列表中的none:none是什么

    浅谈Docker镜像列表中的none:none是什么

    这篇文章主要介绍了Docker镜像列表中的none:none问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Docker swarm 简单使用教程

    Docker swarm 简单使用教程

    Swarm是Docker官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker主机上的各种Docker资源,接下来通过本文给大家介绍Docker swarm 简单使用,感兴趣的朋友一起看看吧
    2021-11-11

最新评论