将 Docker 数据迁移到新磁盘:详细操作指南

将 Docker 数据迁移到新磁盘:详细操作指南

背景

在容器化应用的部署中,Docker 通常将数据存储在默认的 /var/lib/docker 目录。然而,随着容器数量的增加和镜像的累积,该目录可能会迅速占满系统磁盘空间,从而影响系统的正常运行。为了避免磁盘空间不足的问题,可以通过将 Docker 数据目录迁移到容量更大的磁盘上来解决。本指南将详细说明如何将 Docker 数据从默认位置迁移到新磁盘(例如 /dev/sdb1)。


步骤 1:创建临时挂载点并挂载磁盘

注意 :如果磁盘尚未格式化,请先对其进行格式化操作。例如,使用以下命令格式化为 ext4 文件系统:

bash 复制代码
sudo mkfs.ext4 /dev/sdb1

请根据实际需求选择适合的文件系统类型(如 xfs 或其他)。

  1. 使用以下命令创建临时挂载点:

    bash 复制代码
    sudo mkdir /mnt/temp
  2. 将新磁盘挂载到临时目录:

    bash 复制代码
    sudo mount /dev/sdb1 /mnt/temp
  3. 验证挂载是否成功:

    bash 复制代码
    df -h

    确保 /dev/sdb1 显示在输出中并正确挂载到 /mnt/temp


步骤 2:停止 Docker 服务

为了避免迁移过程中出现数据损坏,先停止 Docker 服务:

bash 复制代码
sudo systemctl stop docker

步骤 3:迁移现有数据到临时目录

使用 cp 命令将当前 /var/lib/docker 数据复制到挂载的磁盘中:

bash 复制代码
sudo cp -r -p /var/lib/docker/ /mnt/temp/
  • 选项解释:
    • -r:递归复制目录及其内容。
    • -p:保留文件的权限、时间戳等属性。

等待复制完成,根据数据量大小,可能需要一些时间。


步骤 4:挂载磁盘到 /var/lib/docker

  1. 取消临时挂载:

    bash 复制代码
    sudo umount /mnt/temp
  2. 将磁盘挂载到目标目录:

    bash 复制代码
    sudo mount /dev/sdb1 /var/lib/docker
  3. 为确保磁盘在系统重启后仍然自动挂载,编辑 /etc/fstab 文件,添加以下内容:

    复制代码
    /dev/sdb1    /var/lib/docker    ext4    defaults    0 0

    注意 :请根据磁盘的实际文件系统类型(如 ext4xfs)调整上述配置。


步骤 5:启动 Docker 服务

挂载完成后,重新启动 Docker 服务:

bash 复制代码
sudo systemctl start docker

步骤 6:验证迁移是否成功

  1. 确认 Docker 服务是否正常启动:

    bash 复制代码
    sudo systemctl status docker

    如果状态显示为 active (running),则说明服务正常运行。

  2. 检查 Docker 的数据目录是否已迁移到新磁盘:

    bash 复制代码
    df -h | grep /var/lib/docker

    确认 /var/lib/docker 显示为挂载在 /dev/sdb1 的文件系统上。

  3. 测试容器运行情况:

    运行一个测试容器以确保功能正常:

    bash 复制代码
    docker run --rm hello-world

    如果输出显示 "Hello from Docker!",说明迁移成功且 Docker 正常运行。


通过以上步骤,成功将 Docker 数据从默认目录迁移到新的磁盘 /dev/sdb1,为后续的容器运行提供了更大的存储空间。

相关推荐
小Wang9 小时前
npm私有库创建(docker+verdaccio)
前端·docker·npm
LH_R13 小时前
OneTerm开源堡垒机实战(四):访问授权与安全管控
运维·后端·安全
Raymond运维13 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
JuiceFS1 天前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
chen9451 天前
mysql 3节点mgr集群部署
运维·后端
LH_R2 天前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler2 天前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
少妇的美梦2 天前
logstash教程
运维
容器魔方2 天前
Bloomberg 正式加入 Karmada 用户组!
云原生·容器·云计算
chen9452 天前
k8s集群部署vector日志采集器
运维