Docker 加载镜像时报 no space left on device 的彻底解决方案
目录
- 一、现象与初步判断
- 二、彻底释放空间的思路
- 三、操作步骤(生产可用)
- 1、停止 Docker
- 2、创建新目录
- 3、同步旧数据
- 4、备份旧目录
- 5、修改 Docker 配置
- 6、启动 Docker
- 7、验证是否生效
- 8、删除旧备份(释放空间)
- 四、重新导入镜像
- 五、经验总结
- 六、附加命令:快速清理大文件
在一次部署 FastDDS 镜像的过程中,我们执行如下命令:
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
systemctl stop docker
2、创建新目录
mkdir -p /data/docker
3、同步旧数据
rsync -aH --delete /var/lib/docker/ /data/docker/ \2>/dev/null || cp -a /var/lib/docker/. /data/docker/
4、备份旧目录
mv /var/lib/docker /var/lib/docker.bak
5、修改 Docker 配置
新建或修改 /etc/docker/daemon.json:
{"data-root": "/data/docker"
}
6、启动 Docker
systemctl start docker
7、验证是否生效
docker info | grep "Docker Root Dir"

8、删除旧备份(释放空间)
rm -rf /var/lib/docker.bak

四、重新导入镜像
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.json 的 data-root |
| 验证方式 | docker info + df -h | 观察 /data 增长、/ 降低 |
六、附加命令:快速清理大文件
# 找出最大目录
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
