如何解决由于 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

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

相关推荐
天河归来3 小时前
本地windows环境升级dify到1.11.1版本
java·spring boot·docker
么么...4 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker
学Linux的语莫4 小时前
kompose、docker转k8s
docker·容器·kubernetes
AI视觉网奇5 小时前
nvcr.io 登录方法
docker·ue5
weixin_445476687 小时前
Docker 在 Ubuntu(国内网络)安装及问题解决总结
网络·ubuntu·docker
一点晖光8 小时前
docker配置npm环境变量出现问题
docker·容器·npm
一分半心动9 小时前
windows docker desktop 安装VibeVoice
运维·docker·容器
LucidX9 小时前
Docker核心操作实战
运维·docker·容器
隔壁阿布都9 小时前
Docker Compose中的网络管理
运维·docker·容器