docker 复制容器

在 Docker 中复制容器本身并不是直接支持的操作,但你可以通过以下方法来实现类似的效果:

1.将已有的容器提交为镜像

2.以该镜像创建容器

3.开启容器,进入容器内部

一. 使用 Docker 镜像复制容器

首先,你可以将容器的状态保存为镜像,然后从该镜像创建一个新的容器。步骤如下:

提交容器的更改为镜像

bash 复制代码
docker commit <容器ID或名称> <镜像名>:<标签>

C:\Users\fuyul>docker commit phttp peach:2024
sha256:1d07a8690c4f65a0cc5ef836b14d73facd24f5911b06f3e977fb50010cedce80

成功执行 docker commit 命令时,终端会输出新的镜像 ID。例如:

bash 复制代码
sha256:abc123def4567890...

查找镜像

删除镜像 peach 和 peach1(可不执行)

结果:

从镜像创建新容器

查看在运行的容器

  1. 从镜像创建新容器

    bash 复制代码
    docker run -d <镜像名>:<标签>

    例如:

    bash 复制代码
    docker run -d -v d:\Data:/peachs --name peachs peach:2024 /bin/bash -c "while true; do sleep 1; done"

    解释

  2. docker run: 这是用于运行一个新的容器的 Docker 命令。

  3. -d: 这个选项表示以"分离"模式运行容器,也就是说容器将在后台运行,而不是绑定到当前终端窗口。

  4. -v d:\Data:/peachs: 这个选项将主机上的 d:\Data 目录挂载到容器内的 /peachs 目录。这使得容器可以访问和操作主机上的 d:\Data 目录中的文件。

    • --name peachs: 这个选项为容器指定了一个名称 peachs,这样你可以用这个名称来引用和管理容器,而不需要使用容器的自动生成 ID。

    • peach:2024: 这是要运行的 Docker 镜像的名称和标签。peach 是镜像的名称,2024 是标签或版本号。

    • /bin/bash -c "while true; do sleep 1; done": 这是容器启动时要执行的命令。/bin/bash 启动一个 Bash shell,-c 选项允许你传递一个命令字符串。"while true; do sleep 1; done" 是一个无限循环的 Bash 脚本,这个脚本每秒钟暂停一次,实际上它使容器保持运行状态而不执行其他任务。

    • 这个命令的作用是启动一个基于 peach:2024 镜像的 Docker 容器,挂载主机上的 d:\Data 目录到容器内的 /peachs 目录,以分离模式运行,并在容器内执行一个无限循环的命令来保持容器处于运行状态。容器被命名为 peachs

开启容器

bash 复制代码
docker exec -it 容器名 /bin/bash
docker exec -it peachs /bin/bash

2. 使用 Docker 导出和导入容器

另一种方法是将容器的文件系统导出到 tar 文件中,然后在另一台机器上导入这个 tar 文件来创建新容器:

  1. 导出容器

    docker export <容器ID或名称> -o <文件名>.tar

    例如:
    docker export my_container -o my_container_backup.tar

  2. 导入容器

    docker import <文件名>.tar <新镜像名>:<标签>

    例如:
    docker import my_container_backup.tar my_new_image:latest

  3. 使用导入的镜像创建新容器

    docker run -d <新镜像名>:<标签>

    例如:
    docker run -d my_new_image:latest

3. 克隆容器的配置和数据

如果你需要复制容器的配置和数据,可以使用 Docker Compose 文件来定义和创建容器的配置,然后在另一台机器上使用相同的 Compose 文件来创建容器。这种方法适用于容器的配置和部署一致的场景。

注意事项

  • 容器状态docker exportdocker commit 不会保存容器的运行状态(例如,当前进程状态),它们主要用于保存文件系统的状态。
  • 数据持久性:确保数据存储在持久卷中,这样在复制容器时,数据不会丢失。

根据你的具体需求和场景,选择合适的方法来复制容器。

相关推荐
wenyue1121几秒前
Ease Monitor 会把基础层,中间件层的监控数据和服务的监控数据打通,从总体的视角提供监控分析
运维·中间件·监控
时光の尘10 分钟前
C语言菜鸟入门·关键字·float以及double的用法
运维·服务器·c语言·开发语言·stm32·单片机·c
我们的五年14 分钟前
【Linux课程学习】:进程描述---PCB(Process Control Block)
linux·运维·c++
灼烧的疯狂31 分钟前
K8S + Jenkins 做CICD
容器·kubernetes·jenkins
运维老司机37 分钟前
Jenkins修改LOGO
运维·自动化·jenkins
D-海漠1 小时前
基础自动化系统的特点
运维·自动化
我言秋日胜春朝★1 小时前
【Linux】进程地址空间
linux·运维·服务器
C-cat.1 小时前
Linux|环境变量
linux·运维·服务器
wenyue11211 小时前
Revolutionize Your Kubernetes Experience with Easegress: Kubernetes Gateway API
容器·kubernetes·gateway
yunfanleo2 小时前
docker run m3e 配置网络,自动重启,GPU等 配置渠道要点
linux·运维·docker