news 2026/5/31 1:46:25

Docker Overlay2 迁移至 CentOS Home 完整指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker Overlay2 迁移至 CentOS Home 完整指南

你要将Docker的overlay2存储驱动目录(/var/lib/docker/overlay2,属于overlay文件系统)转移到centos-home逻辑卷(/home目录)下,核心是迁移整个Docker数据目录(因为overlay2是Docker数据目录的子目录,无法单独迁移),从而彻底释放根分区空间,以下是CentOS 7下的精准操作步骤:

核心逻辑

Docker的overlay/overlay2存储目录依赖于Docker的根数据目录(默认/var/lib/docker),因此只需将Docker的核心存储路径从根分区迁移到/home(centos-home),overlay2目录会随之一并转移,无需单独处理。

前置准备

  1. 确认/home(centos-home)空闲空间充足(执行df -h /home);

  2. root用户操作(或全程加sudo);

  3. 停止所有Docker容器和服务,避免数据损坏:

    # 停止所有运行中的容器 docker stop $(docker ps -aq) # 停止Docker服务及socket(关键:避免overlay目录被占用) systemctl stop docker systemctl stop docker.socket # 验证Docker已停止:无输出则成功 ps -ef | grep docker | grep -v grep

完整迁移步骤

步骤1:在/home创建Docker新存储目录
# 创建层级目录(建议命名为/home/docker,便于识别) mkdir -p /home/docker/lib # 设置目录权限(与原/var/lib/docker一致,适配overlay驱动要求) chmod 711 /home/docker/lib chown root:root /home/docker/lib # 可选:关闭SELinux临时放行(CentOS 7默认开启,避免overlay权限拦截) setenforce 0
步骤2:迁移原有Docker数据(含overlay2)到新目录

使用rsync迁移(保留文件权限、软链接,适配overlay的分层存储特性,比cp更安全):

# 迁移/var/lib/docker下所有内容(含overlay2)到/home/docker/lib rsync -avz --numeric-ids /var/lib/docker/ /home/docker/lib/
  • --numeric-ids:保留用户/组的数字ID,避免overlay目录权限错乱;

  • 迁移完成后,可执行ls /home/docker/lib/overlay2验证:能看到原有overlay分层目录即成功。

步骤3:修改Docker配置,指定新存储路径

Docker的存储路径通过/etc/docker/daemon.json配置,无则创建:

# 编辑/创建配置文件 vim /etc/docker/daemon.json

写入以下内容(核心是data-root指定新路径,适配Docker 17.06+版本,覆盖默认的/var/lib/docker):

{ "data-root": "/home/docker/lib", "storage-driver": "overlay2" # 显式指定overlay2驱动,避免自动切换 }
  • 若原有daemon.json有其他配置(如镜像加速),只需新增data-root字段,保持JSON格式正确(逗号分隔,无多余逗号);

  • 保存退出:Esc→ 输入:wq

步骤4:备份原Docker目录(避免冲突)
# 重命名原目录(不直接删除,验证无误后清理) mv /var/lib/docker /var/lib/docker.bak
步骤5:重启Docker并验证overlay路径
# 重载系统配置,重启Docker systemctl daemon-reload systemctl start docker # 验证1:Docker服务正常运行 systemctl status docker # 输出“active (running)”即正常 # 验证2:overlay2目录已迁移到/home(关键!) docker info | grep -E "Docker Root Dir|Storage Driver"

预期输出

Storage Driver: overlay2 Docker Root Dir: /home/docker/lib
步骤6:验证容器/overlay功能正常
# 启动测试容器,验证overlay存储正常 docker run --rm hello-world # 查看新overlay2目录是否生成新文件(确认写入正常) ls -lh /home/docker/lib/overlay2/ | tail -5
  • 若测试容器运行成功,且overlay2目录有新文件生成,说明迁移生效。

步骤7:清理原目录(释放根分区空间)

验证无误后,删除原备份目录:

rm -rf /var/lib/docker.bak

关键注意事项(针对overlay驱动)

  1. overlay2权限要求:新目录必须是root:root、权限711,否则Docker启动时会提示“overlay mount failed”;

  2. SELinux永久适配(可选):

  1. 临时关闭setenforce 0重启后失效,若需永久放行,执行:

    # 编辑SELinux配置 vim /etc/selinux/config # 修改为:SELINUX=permissive # 保存后重启生效(reboot)
  1. overlay分层数据完整性:迁移时必须用rsync -avz --numeric-ids,避免overlay的分层文件(如difflowerdir)损坏;

  2. Docker版本兼容:CentOS 7建议使用Docker 19.03+,避免旧版本对overlay2的兼容性问题。

常见问题与解决方案

问题现象

原因

解决方法

Docker启动报错“overlay2: invalid argument”

SELinux拦截overlay挂载

执行setenforce 0临时关闭,或永久设置SELINUX=permissive

容器启动提示“no space left on device”

新目录权限错误,Docker无法写入

执行chmod 711 /home/docker/lib && chown root:root /home/docker/lib

Docker Root Dir仍显示/var/lib/docker

daemon.json格式错误

执行cat /etc/docker/daemon.json检查(无多余逗号/引号),重新执行systemctl daemon-reload && systemctl restart docker

总结

  1. overlay2作为Docker的存储驱动目录,无法单独迁移,需迁移整个Docker数据目录到/home(centos-home);

  2. 核心操作:停止Docker → rsync迁移数据 → 修改daemon.json指定新路径 → 验证overlay路径

  3. 验证关键:docker info确认存储驱动为overlay2且根目录指向/home,测试容器能正常运行。

迁移完成后,原根分区的overlay目录(/var/lib/docker/overlay2)已被转移,根分区空间会大幅释放,且后续Docker的所有overlay分层数据都会存储在centos-home下。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 1:36:50

强力构建专业硬件测试系统的终极OpenHTF解决方案

强力构建专业硬件测试系统的终极OpenHTF解决方案 【免费下载链接】openhtf The open-source hardware testing framework. 项目地址: https://gitcode.com/gh_mirrors/op/openhtf 🔥 OpenHTF作为Google开源的硬件测试框架,为测试工程师提供了一套…

作者头像 李华
网站建设 2026/5/30 0:24:48

GLM-ASR-Nano-2512模型更新:从旧版本迁移的完整指南

GLM-ASR-Nano-2512模型更新:从旧版本迁移的完整指南 1. 引言 1.1 技术背景与升级动因 随着自动语音识别(ASR)技术在智能助手、会议转录和内容创作等场景中的广泛应用,对高精度、低延迟且资源友好的模型需求日益增长。GLM-ASR-N…

作者头像 李华
网站建设 2026/5/28 23:03:06

茅台自动预约系统:智能抢购的终极解决方案

茅台自动预约系统:智能抢购的终极解决方案 【免费下载链接】campus-imaotai i茅台app自动预约,每日自动预约,支持docker一键部署 项目地址: https://gitcode.com/GitHub_Trending/ca/campus-imaotai 还在为每天手动抢购茅台而烦恼吗&a…

作者头像 李华
网站建设 2026/5/28 22:54:31

JFlash在低功耗模式下的编程稳定性实战研究

JFlash在低功耗模式下的编程稳定性实战研究当你的设备“睡着”了,还能烧录固件吗?在物联网和可穿戴设备的战场上,省电就是生命线。我们设计的系统可能99%的时间都在睡觉——停机、待机、深度休眠……一切为了延长电池寿命。但问题来了&#x…

作者头像 李华
网站建设 2026/5/30 0:28:37

Res-Downloader完整使用指南:高效获取网络资源的智能解决方案

Res-Downloader完整使用指南:高效获取网络资源的智能解决方案 【免费下载链接】res-downloader 资源下载器、网络资源嗅探,支持微信视频号下载、网页抖音无水印下载、网页快手无水印视频下载、酷狗音乐下载等网络资源拦截下载! 项目地址: https://gitc…

作者头像 李华
网站建设 2026/5/28 4:11:48

Qwen3-VL-2B入门教程:零基础搭建多模态AI平台

Qwen3-VL-2B入门教程:零基础搭建多模态AI平台 1. 引言 1.1 学习目标 本文旨在为初学者提供一份完整的 Qwen3-VL-2B-Instruct 模型部署与使用指南。通过本教程,您将掌握从环境准备到网页端交互的全流程操作,无需任何深度学习或模型部署经验…

作者头像 李华