Docker 加载镜像时报 no space left on device 的彻底解决方案

目录

在一次部署 FastDDS 镜像的过程中,我们执行如下命令:

bash 复制代码
sh start_fastdds_pub.sh

脚本内部会先删除旧镜像、再通过 docker load -i fastdds_2.8.0.tar 重新加载镜像。

结果报错:

复制代码
write /blobs/sha256/635e6bb12b404837cd39744c12bf83886fb46a0ef9550b7f945fa991d9d4c802: no space left on device

即 "磁盘空间不足"。本文记录从排查到彻底解决的完整过程。


一、现象与初步判断

运行 df -h 后发现:

复制代码
/dev/sda3        46G   45G  818M  99% /
/dev/sda5        30G  359M   30G   2% /data

根分区(/)几乎被占满,而 Docker 的默认数据目录 /var/lib/docker 正好在这个分区上。

这意味着 Docker 镜像、容器的写层都挤在 / 里,导致空间爆满。


二、彻底释放空间的思路

既然 /data 分区还有 30G 空闲,我们可以把 Docker 的数据根目录迁过去,这样以后所有镜像、容器都不再占用 /


三、操作步骤(生产可用)

1、停止 Docker

bash 复制代码
systemctl stop docker

2、创建新目录

bash 复制代码
mkdir -p /data/docker

3、同步旧数据

bash 复制代码
rsync -aH --delete /var/lib/docker/ /data/docker/ \
  2>/dev/null || cp -a /var/lib/docker/. /data/docker/

4、备份旧目录

bash 复制代码
mv /var/lib/docker /var/lib/docker.bak

5、修改 Docker 配置

新建或修改 /etc/docker/daemon.json

bash 复制代码
{
  "data-root": "/data/docker"
}

6、启动 Docker

bash 复制代码
systemctl start docker

7、验证是否生效

bash 复制代码
docker info | grep "Docker Root Dir"

8、删除旧备份(释放空间)

bash 复制代码
rm -rf /var/lib/docker.bak

四、重新导入镜像

bash 复制代码
docker load -i /opt/data/fast_demo/fastdds_2.8.0.tar

若显示:

复制代码
Loaded image: fastdds:2.8.0

说明镜像成功导入。


五、经验总结

项目 原因 解决方式
报错内容 /var/lib/docker 空间耗尽 查看根分区与 overlay 挂载情况
docker system prune 无效 overlay 层未被清理 手动清理或迁移 Docker 根目录
推荐做法 将 Docker 数据迁到大分区 /data 修改 daemon.jsondata-root
验证方式 docker info + df -h 观察 /data 增长、/ 降低

六、附加命令:快速清理大文件

bash 复制代码
# 找出最大目录
du -xh /var/lib/docker | sort -h | tail -n 20

# 截断容器日志
find /var/lib/docker/containers -name "*-json.log" -exec truncate -s 0 {} \;

# 清理系统日志
journalctl --vacuum-size=500M
相关推荐
人生苦短1283 小时前
Kubernetes(k8s)
云原生·容器·kubernetes
喜欢你,还有大家9 小时前
Docker-仓库-镜像制作
运维·docker·容器
武子康11 小时前
Java-166 Neo4j 安装与最小闭环 | 10 分钟跑通 + 远程访问 Docker neo4j.conf
java·数据库·sql·docker·系统架构·nosql·neo4j
计算机小手14 小时前
使用 llama.cpp 在本地高效运行大语言模型,支持 Docker 一键启动,兼容CPU与GPU
人工智能·经验分享·docker·语言模型·开源软件
岚天start15 小时前
KubeSphere在线安装单节点K8S集群
docker·容器·kubernetes·k8s·kubesphere·kubekey
xyhshen15 小时前
记录一次K8S跨命名空间访问 xxx.xxx.svc.cluster.local 类似内部服务不通的问题
云原生·容器·kubernetes
栗子~~15 小时前
shell-基于k8s/docker管理容器、监控模型训练所消耗的最大CPU与最大内存脚本
docker·容器·kubernetes
海鸥8115 小时前
在k8s中部署seaweedfs,上传文件到seaweedfs方法
云原生·容器·kubernetes
半梦半醒*15 小时前
k8s——pod详解2
linux·运维·docker·容器·kubernetes·负载均衡