本文介绍由于 Docker 的大日志文件所导致的磁盘空间不足进而引发的一些系统问题,例如:
- 磁盘上无法写入文件
- 作为 K8s 的唯一节点,由于磁盘空间不足,导致 Pod 无法被调度到该节点上,一直处于 Pending 状态。
解决思路其实很简单就是 "找到 Docker 的大日志文件并删除它!"。
步骤一、确定大目录
-
首先我们需要查看 /var/lib/docker 目录下各子目录的大小,以此来找到大目录,执行命令如下:
bashdu -sh /var/lib/docker/*输出示例:

-
通过输出列表,找到占用空间较大的目录,例如:/var/lib/docker/overlay2
步骤二、确定 .log 大文件
-
通过【步骤一】中确认的大目录,从该目录中确认是否存在占用空间较大的 .log 文件,执行命令如下:
bashsudo find ${目标大目录} -name '*.log' -exec du -sh {} \; | sort -hr将 ${目标大目录} 替换为【步骤一】中确认的大目录,例如:/var/lib/docker/overlay2
-
根据输出列表,找到 .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 日志爆炸的问题,可通过如下操作:
-
编辑或创建 /etc/docker/daemon.json 文件,在该文件中添加如下内容:
json{ "log-driver": "json-file", "log-opts": { "max-size": "100m", // 单个日志文件最大 100MB "max-file": "3" // 最多保留 3 个历史日志文件 } } -
重启 Docker 使日志策略生效,执行命令如下:
bashsudo systemctl restart docker(注:此配置只对新创建的容器生效。已有容器需要重建才能应用新日志策略)