docker打开滚动日志

在 Docker 中启用滚动日志(log rotation)可以帮助你管理容器日志的大小,避免日志文件占用过多磁盘空间。以下是具体的操作步骤:


1. 修改 Docker 守护进程配置

Docker 的日志配置是通过 daemon.json 文件管理的。你需要修改此文件以启用滚动日志。

  1. 打开或创建 daemon.json 文件:

    复制代码
    sudo vi /etc/docker/daemon.json
  2. 添加或修改以下内容:

    复制代码
      "log-driver": "json-file",
      "log-opts": {
        "max-size": "50m",
        "max-file": "3"
      }
    • max-size:单个日志文件的最大大小(例如 10m 表示 10MB)。
    • max-file:保留的日志文件数量(例如 3 表示保留 3 个日志文件)。
  3. 保存并退出编辑器。


2. 重启 Docker 服务

使配置生效:

复制代码
sudo systemctl restart docker

3. 验证配置

  1. 检查 daemon.json 是否生效:

    复制代码
    docker info | grep Logging

    输出应包含 json-file 和你的日志配置。

  2. 启动一个容器并检查日志文件:

    复制代码
    docker run --name test-container -d busybox sh -c "while true; do echo 'Hello, Docker!'; sleep 1; done"
  3. 查看日志文件是否滚动:

    复制代码
    ls -lh /var/lib/docker/containers/<container-id>/<container-id>-json.log*

    你会看到多个日志文件(例如 -json.log, -json.log.1, -json.log.2)。


4. 为单个容器配置日志(可选)

如果你只想为某个容器启用滚动日志,可以在运行容器时指定日志选项:

复制代码
docker run --name test-container \  --log-driver json-file \  --log-opt max-size=10m \  --log-opt max-file=3 \  -d busybox sh -c "while true; do echo 'Hello, Docker!'; sleep 1; done"

5. 清理旧日志

如果需要手动清理旧日志,可以使用以下命令:

复制代码
sudo docker logs -f <container-id> > /dev/null 2>&1sudo truncate -s 0 /var/lib/docker/containers/<container-id>/<container-id>-json.log

6. 注意事项

  • 日志文件默认存储在 /var/lib/docker/containers/<container-id>/ 目录下。
  • 如果磁盘空间不足,建议定期清理旧日志或增加 max-sizemax-file 的值。
  • 如果你使用其他日志驱动(如 syslogjournald),滚动日志的配置方式会有所不同。
相关推荐
JIAKSK26 分钟前
VitePress 接入百度统计:全面教程与优化指南
运维·数据可视化
网硕互联的小客服1 小时前
未来趋势:AI与量子计算对服务器安全的影响
运维·服务器·网络·网络安全·量子计算
宇钶宇夕1 小时前
STEP 7 MicroWIN SMART V2.2 的详细安装步骤及注意事项
运维·服务器·程序人生·自动化
czhc11400756632 小时前
Linux 77 FTP
linux·运维·服务器
魂尾ac2 小时前
Centos Docker 安装(100%成功)
linux·docker·centos
天若有情6732 小时前
【Linux】02_CentOS 7 开机运行级别详解:从基础概念到实战配置
linux·运维·centos
張萠飛2 小时前
Linux中程序的limits中的Max open files的配置由哪些参数决定
linux·运维·服务器
Johny_Zhao8 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
zwjapple9 小时前
docker-compose一键部署全栈项目。springboot后端,react前端
前端·spring boot·docker
一心09210 小时前
ubuntu 20.04.6 sudo 源码包在线升级到1.9.17p1
运维·ubuntu·sudo·漏洞升级