docker基础(八)之docker commit,docker tag,docker cp,docker diff

概述

用于学习和记录,以下内容来自chatgpt3.5,网络等,补充例子。
本文介绍了docker commit,docker tag,docker cp,docker diff的基础用法,及相关options的详细解释和例子。

docker系列其他文章:docker专栏

docker commit

docker commit :从容器创建一个新的镜像。

语法

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

OPTIONS说明:

  • -a :提交的镜像作者;
  • -c :使用Dockerfile指令来创建镜像;
  • -m :提交时的说明文字;
  • -p :在commit时,将容器暂停。
    PS: (因为docker commit是把容器当前状态提交为镜像快照,这个-p是提交快照的时候,把当前容器给暂停)

docker commit --help

在这里插入图片描述

实例

假设已经有一个正在运行的容器,其名称为my_container,想要将其保存为一个新的镜像。

首先,使用以下命令查找容器的ID或名称:

docker ps

在输出中,找到要创建镜像的容器的ID名称。假设它是my_container

运行以下命令来创建镜像:

docker commit my_container my_image:tag

在上述命令中,将my_container替换为要创建镜像的容器的ID或名称,my_image替换为想要为镜像设置的名称,tag是镜像的标签(可选)。

例如,要将容器my_container创建为名为my_image的镜像,可以运行以下命令:

docker commit my_container my_image

这将在本地Docker环境中创建一个新的镜像。

完成后,可以使用以下命令查看新创建的镜像列表:

docker images

在输出中,将看到刚刚创建的my_image镜像。

现在,已经成功地通过现有容器创建了一个新的镜像。

请注意,使用docker commit命令创建镜像时,将保存容器的当前状态作为快照。这包括容器中的文件、进程、网络设置等
但是,这种方式创建的镜像可能不够灵活和可重复 ,因为它们可能会包含不必要的或临时性的文件和状态。

如果需要更复杂和可重复的镜像构建过程,建议使用Dockerfile来定义镜像的构建步骤和配置。

使用场景

以下是一些docker commit命令的使用场景:

  • 自定义镜像:当对现有容器进行了一些定制化的修改,例如安装了特定软件包、调整了配置,希望将这些修改保存为一个新的镜像,这时就可以使用docker commit命令。
  • 实验和调试:在开发过程中,为了节省时间,可能会对容器进行一些实验性的修改或者调试。使用docker commit可以保存这些调试过程中的容器状态,方便后续查看或者分享
  • 创建快照镜像:当需要在特定时间点对容器的状态进行快照,以便稍后进行回滚或者比对容器状态时,可以使用docker commit命令。
  • 将容器状态保存为镜像:在CI/CD流程中,可能会遇到需要将特定步骤的容器状态保存为镜像的情况,通过docker commit可以方便地实现此目的。

总的来说,docker commit命令适用于需要将容器状态保存为新镜像以及定制化镜像的场景。这种方式可以帮助用户更轻松地管理和共享容器的特定状态。

docker tag

docker tag : 标记本地镜像,将其归入某一仓库。

语法

docker tag [OPTIONS] IMAGE[:TAG] [REGISTRYHOST/][USERNAME/]NAME[:TAG]

其中
SOURCE_IMAGE是要标记的源镜像的名称或ID。
TAG是可选的,用于指定镜像的标签。如果未指定标签,将使用默认的latest标签。
TARGET_IMAGE是目标镜像的名称或ID。

示例

  • 给现有的镜像添加标签:
docker tag my_image:latest my_image:1.0

这将为名为my_image的镜像添加一个名为1.0的标签。

  • 为镜像添加命名空间和标签:
docker tag my_image:latest my_registry/my_image:1.0

这将为名为my_image的镜像添加一个名为1.0的标签,并将其命名空间设置为my_registry。

  • 使用镜像ID进行标记:
docker tag 0123456789ab my_image:1.0

这将使用ID为0123456789ab的镜像添加一个名为1.0的标签。

  • 标记远程镜像:
docker tag my_image:latest my_registry/my_image:1.0

这将为名为my_image的本地镜像添加一个名为1.0的标签,并将其命名空间设置为my_registry,从而创建一个带有标签的远程镜像。

请注意,docker tag命令只是为镜像添加了一个新的标签,而不会创建新的镜像。标签只是对现有镜像的引用,可以更方便地引用和管理镜像。

使用场景

docker tag命令的使用场景包括:

  • 标记镜像版本:通过给镜像添加标签,可以方便地标识和管理不同版本的镜像。例如,可以为每个镜像版本添加一个唯一的标签,如1.0、2.0等。

  • 创建镜像别名:使用docker tag命令,可以为同一个镜像创建多个标签,从而创建镜像的别名。这样,可以使用不同的标签来引用同一个镜像,使得镜像在不同环境或用途中更易于识别和使用。

  • 上传镜像到私有仓库:如果使用的是私有的Docker镜像仓库,可以使用docker tag命令为镜像添加仓库的命名空间,并指定标签,然后使用docker push命令将镜像推送到私有仓库中。

  • 管理分支和发布:在开发过程中,可以使用docker tag命令为不同的代码分支创建不同的镜像标签。这样,可以轻松地在不同的环境中部署和测试不同的代码分支。

  • 复制镜像到其他环境:通过使用docker tag命令,可以为现有的镜像创建一个新的标签,并将其传输到其他环境中。这样,可以在不同的机器或服务器之间复制和使用相同的镜像。

总之,docker tag命令提供了一种方便的方式来管理和引用Docker镜像,使得在不同环境和用途中更加灵活和可控。

为什么要这样做呢?

在同一时间点给同一个镜像打多个标签通常是为了将同一版本的镜像在不同的场景中使用不同的标签。 这样可以使得镜像在不同环境中可以被更方便地调用和识别。

例如,假设我们有一个版本为1.0的镜像,我们可以给它打上以下标签:

docker build -t myapp:1.0 -t username/myapp:1.0 -t myapp:latest -t username/myapp:latest .

"myapp:1.0":用于在稳定的生产环境中使用;
"username/myapp:1.0":用于推送到远程仓库;
"myapp:latest":代表最新版本,在开发环境中可以使用;
"username/myapp:latest":代表最新版本,也用于推送到远程仓库。

这样做可以实现在单个构建过程中定义多个标签,并且确保它们都指向同一个镜像。这样做有助于提高镜像的灵活性、可维护性和适用性。

docker cp

docker cp :用于容器与主机之间的数据拷贝。

语法

docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH
docker cp [OPTIONS] SRC_PATH CONTAINER:DEST_PATH

CONTAINER是要复制文件的容器名称或ID。
SRC_PATH是源文件或目录的路径。
DEST_PATH是目标文件或目录的路径。

docker cp命令用于在本地文件系统和运行中的Docker容器之间复制文件或目录。

OPTIONS说明:

-a, --archive:将文件或目录以归档模式复制,保留所有元数据和权限。
-L, --follow-link:跟随符号链接进行复制。

docker cp --help

在这里插入图片描述

示例

以下是一些示例:

  • 从容器复制文件到本地文件系统:
docker cp my_container:/app/logs/app.log /tmp/app.log

这将从名为my_container的容器中复制/app/logs/app.log文件到本地文件系统的/tmp/app.log路径。

  • 从容器复制整个目录到本地文件系统:
docker cp my_container:/app/logs/ /tmp/logs/

这将从名为my_container的容器中复制/app/logs/目录及其内容到本地文件系统的/tmp/logs/路径。

  • 将本地文件复制到容器:
docker cp /tmp/app.log my_container:/app/logs/app.log

这将从本地文件系统的/tmp/app.log文件复制到名为my_container的容器中的/app/logs/app.log路径。

  • 将本地目录复制到容器:
docker cp /tmp/logs/ my_container:/app/logs/

这将从本地文件系统的/tmp/logs/目录及其内容复制到名为my_container的容器中的/app/logs/路径。

  • -L 选项的使用
    当容器内有一个符号链接指向的目标文件时,我们可以通过以下示例来演示 -L 选项的使用:

假设容器内有一个符号链接 /app/link.txt,它指向文件 /app/data.txt。我们将使用 docker cp 命令将链接指向的目标文件复制到主机上的 /tmp 目录。

docker cp -L mycontainer:/app/link.txt /tmp

上述命令将复制容器内的 /app/link.txt 符号链接指向的文件 /app/data.txt 到主机上的 /tmp 目录。

请注意:

  • 如果不使用 -L 选项,只会复制符号链接本身,而不会跟随链接指向的目标文件。因此,如果不加 -L
    选项,上述命令将在主机上创建一个名为 link.txt 的文件,而不是复制链接指向的目标文件。

  • docker cp命令需要指定容器的名称或ID,并且必须在容器运行时才能复制文件**。此外,目标路径必须是容器内的绝对路径。

docker diff

docker diff命令用于查看容器内部文件系统的变化。它将显示容器中添加、修改或删除的文件和目录。

语法

docker diff [OPTIONS] CONTAINER

CONTAINER是要检查文件系统变化的容器名称或ID。

示例

  • 查看容器内部文件的变化:
docker diff my_container

这将显示名为my_container的容器中文件系统的变化列表。添加的文件和目录以A标记,修改的文件以C标记,删除的文件以D标记。

  • 监控容器内部文件的变化:

docker diff命令可以与其他命令结合使用,以监控容器内部文件系统的变化。例如,可以使用watch命令定期运行docker diff来实时监测文件的变化。

watch -n 1 "docker diff my_container"

这将每秒钟运行一次docker diff命令,并显示容器中文件系统的变化。

使用场景:

  • 调试容器:当遇到容器中文件系统相关的问题时,可以使用docker diff命令来查看文件的变化,以确定是否有意外的修改或删除操作。

  • 监测容器的行为:通过定期运行docker diff命令,可以监测容器内部文件系统的变化,以确保容器的行为符合预期。

  • 容器安全审计:使用docker diff命令可以检查容器中的文件变化,以进行安全审计。可以查看容器中添加或修改的文件,以确保没有未经授权的更改。

请注意,docker diff命令只能查看容器内部文件系统的变化,而不能对容器外部的文件系统进行操作。

  • 29
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值