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

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

相关推荐
yeyuningzi4 分钟前
Debian 12环境里部署nginx步骤记录
linux·运维·服务器
wclass-zhengge18 分钟前
K8S篇(基本介绍)
云原生·容器·kubernetes
颜淡慕潇24 分钟前
【K8S问题系列 |1 】Kubernetes 中 NodePort 类型的 Service 无法访问【已解决】
后端·云原生·容器·kubernetes·问题解决
EasyCVR1 小时前
萤石设备视频接入平台EasyCVR多品牌摄像机视频平台海康ehome平台(ISUP)接入EasyCVR不在线如何排查?
运维·服务器·网络·人工智能·ffmpeg·音视频
wowocpp2 小时前
ubuntu 22.04 硬件配置 查看 显卡
linux·运维·ubuntu
萨格拉斯救世主2 小时前
jenkins使用slave节点进行node打包报错问题处理
运维·jenkins
川石课堂软件测试2 小时前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
pk_xz1234564 小时前
Shell 脚本中变量和字符串的入门介绍
linux·运维·服务器
小珑也要变强4 小时前
Linux之sed命令详解
linux·运维·服务器
Lary_Rock6 小时前
RK3576 LINUX RKNN SDK 测试
linux·运维·服务器