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

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

相关推荐
w6100104664 小时前
CKAD-2026-Ingress
运维·k8s·ckad
zzzsde8 小时前
【Linux】库的制作和使用(3)ELF&&动态链接
linux·运维·服务器
CQU_JIAKE8 小时前
4.3【A]
linux·运维·服务器
AI周红伟8 小时前
OpenClaw是什么?OpenClaw能做什么?OpenClaw详细介绍及保姆级部署教程-周红伟
大数据·运维·服务器·人工智能·微信·openclaw
Elastic 中国社区官方博客8 小时前
当 TSDS 遇到 ILM:设计不会拒绝延迟数据的时间序列数据流
大数据·运维·数据库·elasticsearch·搜索引擎·logstash
qing222222228 小时前
Linux中修改mysql数据表
linux·运维·mysql
杨云龙UP8 小时前
Oracle 中 NOMOUNT、MOUNT、OPEN 怎么理解? 在不同场景下如何操作?_20260402
linux·运维·数据库·oracle
Amctwd8 小时前
【Linux】OpenCode 安装教程
linux·运维·服务器
和小潘一起学AI9 小时前
SHH隧道内网穿透
运维·服务器
wwj888wwj9 小时前
Docker基础(复习)
java·linux·运维·docker