openEuler系统迁移 Docker 数据目录到 /home,解决Docker 临时文件占用大问题

根据错误信息 write /var/lib/docker/tmp/...: no space left on device,问题的根源是 根分区(/)的磁盘空间不足 ,而非 /home 分区的问题。以下是详细解释和解决方案:


问题原因分析

  1. Docker 临时文件占用根分区空间

    • docker save 命令在导出镜像时,会先将镜像数据暂存到 /var/lib/docker/tmp 目录(属于根分区 /)。
    • 即使你的目标路径 /home 有 2TB 空间,但临时文件的写入路径 /var/lib/docker/tmp 所在的根分区空间不足,导出操作仍会失败。
  2. 根分区空间不足

    • 根据之前的 df -h 输出:

      bash 复制代码
      /dev/mapper/openeuler-root   69G   60G  5.8G   92% / 

      根分区只剩 5.8G 空间,远小于需要导出的镜像大小(21.3GB),导致临时文件无法写入。


解决方案

方法:迁移 Docker 数据目录到 /home

如果根分区空间无法释放足够空间,必须将 Docker 数据目录迁移到 /home 分区 ,这样 docker save 的临时文件也会在 /home 下生成。

步骤如下
  1. 停止 Docker 服务

    bash 复制代码
    sudo systemctl stop docker
  2. 创建新数据目录(如 /home/docker

    bash 复制代码
    sudo mkdir -p /home/docker
    sudo chown -R root:root /home/docker
  3. 迁移现有数据

    bash 复制代码
    # 将旧数据复制到新目录(可能需要时间)
    sudo rsync -avz /var/lib/docker/ /home/docker/
  4. 配置 Docker 使用新目录

    bash 复制代码
    # 创建 Docker 守护进程配置文件
    sudo mkdir -p /etc/systemd/system/docker.service.d/
    sudo tee /etc/systemd/system/docker.service.d/devicemapper.conf <<EOF
    [Service]
    ExecStart=
    ExecStart=/usr/bin/dockerd --graph=/home/docker
    EOF
  5. 重启 Docker 服务

    bash 复制代码
    sudo systemctl daemon-reload
    sudo systemctl start docker
    sudo systemctl enable docker

注意:启动docker出现了个错误

解决方法:

bash 复制代码
sudo vim /etc/systemd/system/docker.service.d/devicemapper.conf
bash 复制代码
修改前的错误配置:
[Service]
ExecStart=
ExecStart=/usr/bin/dockerd --graph=/home/docker
bash 复制代码
修改后的正确配置:
[Service]
ExecStart=
ExecStart=/usr/bin/dockerd --data-root=/home/docker

重启

bash 复制代码
sudo systemctl daemon-reload
sudo systemctl restart docker

确认 Docker 数据目录已正确指向 /home/docker:

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

输出应为:Docker Root Dir: /home/docker

  1. 删除旧数据(可选)

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

注意事项

  1. 临时文件空间需求

    • docker save 需要额外的临时空间,因此即使 /home 有 2TB,根分区仍需至少 镜像大小的 1.5 倍 空间(如果未迁移数据目录)。
  2. 迁移后的路径权限

    • 确保 /home/docker 的权限正确:

      bash 复制代码
      sudo chown -R root:root /home/docker
      sudo chmod 755 /home/docker
  3. 日志文件清理

    • 如果容器日志占用空间,可以清理日志:

      bash 复制代码
      # 清理所有容器日志
      sudo find /var/lib/docker/containers/ -name "*.log" -exec truncate -s 0 {} \;

验证操作成功

  1. 检查根分区空间

    bash 复制代码
    df -h /
    # 确保根分区使用率 < 90%
  2. 我重新尝试导出

    bash 复制代码
    docker save -o /home/mis-tei-6.0.0-300I-Duo-aarch64.tar swr.cn-south-1.myhuaweicloud.com/ascendhub/mis-tei:6.0.0-300I-Duo-aarch64

成功


总结

  • 根本原因/var/lib/docker/tmp 所在的根分区空间不足。
  • 解决方案 :清理根分区或迁移 Docker 数据目录到 /home
  • 长期建议:定期清理 Docker 资源,并监控磁盘使用情况。

如果问题仍未解决,请提供更多以下信息:

  • docker system df 输出(查看镜像占用情况)。
  • df -h /var/lib/docker(确认数据目录空间)。
  • Docker 版本:docker --version
相关推荐
tonngw2 小时前
【Mac 从 0 到 1 保姆级配置教程 16】- Docker 快速安装配置、常用命令以及实际项目演示
macos·docker·容器·开源·github·docker desktop·orbstack
debug 小菜鸟4 小时前
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
docker·云计算·aws
SpikeKing4 小时前
Server - 使用 Docker 配置 PyTorch 研发环境
pytorch·docker·llm
斯普信云原生组6 小时前
Docker构建自定义的镜像
java·spring cloud·docker
2201_761199046 小时前
k8s4部署
云原生·容器·kubernetes
小柏ぁ6 小时前
calico/node is not ready: BIRD is not ready: BGP not established with xxx
运维·docker·kubernetes
三劫散仙7 小时前
kubernetes jenkins pipeline优化拉取大仓库性能指定分支+深度
容器·kubernetes·jenkins
西京刀客7 小时前
k8s热更新-subPath 不支持热更新
云原生·容器·kubernetes·configmap·subpath
weixin_434936288 小时前
k8S 命令
linux·容器·kubernetes
nuczzz10 小时前
GPU虚拟化
docker·kubernetes·k8s·gpu·nvidia