如何解决由于 Docker 的大日志文件导致磁盘空间不足的问题

本文介绍由于 Docker 的大日志文件所导致的磁盘空间不足进而引发的一些系统问题,例如:

  • 磁盘上无法写入文件
  • 作为 K8s 的唯一节点,由于磁盘空间不足,导致 Pod 无法被调度到该节点上,一直处于 Pending 状态。

解决思路其实很简单就是 "找到 Docker 的大日志文件并删除它!"。

步骤一、确定大目录

  1. 首先我们需要查看 /var/lib/docker 目录下各子目录的大小,以此来找到大目录,执行命令如下:

    bash 复制代码
    du -sh /var/lib/docker/*

    输出示例:

  2. 通过输出列表,找到占用空间较大的目录,例如:/var/lib/docker/overlay2

步骤二、确定 .log 大文件

  1. 通过【步骤一】中确认的大目录,从该目录中确认是否存在占用空间较大的 .log 文件,执行命令如下:

    bash 复制代码
    sudo find ${目标大目录} -name '*.log' -exec du -sh {} \; | sort -hr

    ${目标大目录} 替换为【步骤一】中确认的大目录,例如:/var/lib/docker/overlay2

  2. 根据输出列表,找到 .log 大文件

    如果我们从输出列表中发现某个 .log 文件有几十个G,那基本上就可以把它删除来达到释放空间的目的了。

步骤三、删除 .log 大文件

通过【步骤三】我们确定了要删除的 .log 大文件,剩下的就是删除它了,执行命令如下:

bash 复制代码
sudo truncate -s 0 ${日志文件}

${日志文件} 替换为【步骤二】中确认要删除的 .log 大文件,例如:/var/lib/docker/overlay2/fd9846cef0d3c6c0df342.../merged/logs/datapix-server/datapix-server.2025-12-15.log

步骤四、优化 Docer 日志策略

为了预防以后再次发生 Docker 日志爆炸的问题,可通过如下操作:

  1. 编辑或创建 /etc/docker/daemon.json 文件,在该文件中添加如下内容:

    json 复制代码
    {
      "log-driver": "json-file",
      "log-opts": {
        "max-size": "100m", // 单个日志文件最大 100MB
        "max-file": "3" // 最多保留 3 个历史日志文件
      }
    }
  2. 重启 Docker 使日志策略生效,执行命令如下:

    bash 复制代码
    sudo systemctl restart docker

    (注:此配置只对新创建的容器生效。已有容器需要重建才能应用新日志策略)

相关推荐
小p21 小时前
docker学习: 2. 构建镜像Dockerfile
docker
小p2 天前
docker学习: 1. docker基本使用
docker
崔小汤呀2 天前
Docker部署Nacos
docker·容器
缓解AI焦虑2 天前
Docker + K8s 部署大模型推理服务:资源划分与多实例调度
docker·容器
1candobetter2 天前
Docker Compose Build 与 Up 的区别:什么时候必须重建镜像
docker·容器·eureka
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
BugShare3 天前
继《小爱音响》详细说下怎么部署,尤其是关于Docker部分
docker·nas·xiaomusic
小马爱打代码3 天前
Docker:完全指南从入门到精通
运维·docker·容器
ITKEY_3 天前
docker 容器端口映射消失
docker·容器