1、commit命令作用

在运行的容器中,并在镜像的基础上做了一些修改,我们希望保存起来,封装成一个新的镜像,方便我们以后使用,也就是提交容器副本,使之成为一个新的镜像。

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

例如:

我们以Tomcat镜像为例,运行启动Tomcat镜像后得到Tomcat容器,我们在Tomcat容器中做了一些自定义的设计或者修改,使此时的Tomcat容器成为符合我们需求的容器,之后就可以通过docker commit命令提交生成一个新的Tomcat镜像,也就是生成一个符合我们使用需求的Tomcat镜像,再下次在使用Tomcat容器时,直接使用我们自定义的新Tomcat镜像即可。

2、commit命令说明

命令格式如下:

docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]

OPTIONS说明:

  • -a:提交的镜像作者;
  • -c:使用Dockerfile指令来创建镜像;
  • -m:提交时的说明文字;
  • -p:在commit时,将容器暂停。

3、示例演示

我们通过示例加深对镜像操作和理解。

步骤1:查看本地Docker镜像

[root@192 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 300e315adb2f 3 months ago 209MB

步骤2:下载Tomcat镜像到本地

[root@192 ~]# docker pull tomcat:9.0
9.0: Pulling from library/tomcat
b9a857cbf04d: Pull complete
d557ee20540b: Pull complete
3b9ca4f00c2e: Pull complete
667fd949ed93: Pull complete
661d3b55f657: Pull complete
511ef4338a0b: Pull complete
a56db448fefe: Pull complete
00612a99c7dc: Pull complete
326f9601c512: Pull complete
c547db74f1e1: Pull complete
Digest: sha256:94cc18203335e400dbafcd0633f33c53663b1c1012a13bcad58cced9cd9d1305
Status: Downloaded newer image for tomcat:9.0
docker.io/library/tomcat:9.0 [root@192 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
tomcat 9.0 040bdb29ab37 2 months ago 649MB
centos latest 300e315adb2f 3 months ago 209MB

步骤3:启动容器

执行命令:docker run -it --name tomcat123 -p 8888:8080 tomcat:9.0(注意该命令最后不要加/bin/bash

-p用法可以看前面的Docker安装Tomcat容器的练习)

如下图:

提示:-P大P的用法如下:

也可以执行命令:docker run -d -p 6666: 8080 tomcat:9.0,进行Tomcat容器的后台启动。

步骤4:对Tomcat镜像进行修改

把Tomcat中webapps.dist目录中的内容,全部拷贝到webapps目录中。

我们在XShell中新建一个窗口,进入Tomcat容器,进行修改。

# 进入Tomcat容器中
[root@192 ~]# docker exec -it tomcat123 /bin/bash
root@d60ed0bff852:/usr/local/tomcat# # webapps.dist目录中的内容,全部拷贝到webapps目录中。
root@d60ed0bff852:/usr/local/tomcat# cp -r webapps.dist/* webapps
root@d60ed0bff852:/usr/local/tomcat# ls -l webapps
total 4
drwxr-xr-x. 3 root root 223 Mar 18 05:02 ROOT
drwxr-xr-x. 15 root root 4096 Mar 18 05:02 docs
drwxr-xr-x. 7 root root 99 Mar 18 05:02 examples
drwxr-xr-x. 6 root root 79 Mar 18 05:02 host-manager
drwxr-xr-x. 6 root root 114 Mar 18 05:02 manager

说明:

因为发现默认Tomcat的webapps目录中是没有应用,这是镜像的原因,官方的镜像默认webapps下面是没有文件的。

所以通过上面的操作,当我们启动Tomcat镜像的时候,就可以访问到Tomcat的欢迎界面了。(具体可看前面的Docker安装Tomcat容器的练习)

步骤5:提交镜像

将我们操作过的Tomcat容器通过commit提交为一个新的镜像,我们以后就使用我们修改过的镜像即可。

命令如下:

docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]

示例:

# 退出Tomcat容器
root@d60ed0bff852:/usr/local/tomcat# exit
exit # 执行docker commit 提交生成新的tomcat镜像
[root@192 ~]# docker commit -m="add webapps App" -a="sunwukong" d60ed0bff852 tomcat123:1.0
sha256:e42c33552c6c3df7587f254803a0c1b4a686ff78d9f5e28aed0a94a3c91b22a4
[root@192 ~]# # 查看本地Docker镜像
[root@192 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
tomcat123 1.0 e42c33552c6c About a minute ago 653MB
tomcat 9.0 040bdb29ab37 2 months ago 649MB
centos latest 300e315adb2f 3 months ago 209MB

我们可以看到本地Docker镜像多可以一个tomcat123镜像,且是1.0版本。

也可以发现tomcat123镜像的大小为653MB,比原先的Tomcat镜像649MB多了几兆。

提示:

docker commit -m="add webapps App" -a="sunwukong" d60ed0bff852 tomcat123:1.0

命令的最后tomcat123:1.0为自定义的镜像名和版本,也可以在前面加入Namespace的,也就如abc/tomcat123:1.0,这个abc就叫Namespace。你就可以想象于Java中,类前面的包名。我们拉取镜像的时候也经常会看到一些这样命名的包,如用到过的portainer/portainer工具。

关于Namespace命名空间,以后会详细讲解。

步骤6:启动自定义的Tomcat镜像

执行命令:docker run -it -p 8888:8080 tomcat123:1.0

这里提示一下,如果需要让外部访问容器的服务,一定要进行端口映射。

直接在外部浏览器中访问,如下:

可以直接显示Tomcat服务的欢迎界面。

到了这里大概才算是入门Dokcer!

『现学现忘』Docker基础 — 27、Docker镜像的commit操作的更多相关文章

  1. 『现学现忘』Docker基础 — 9、Docker简介

    目录 1.什么是Docker? 2.Docker的出现解决了什么问题? 3.Docker的特别之处 4.Docker相关网站 1.什么是Docker? 2010年dotCloud公司在旧金山成立,PA ...

  2. 『现学现忘』Docker基础 — 16、Docker中的基本概念和底层原理

    目录 1.Docker的底层原理 2.Docker中常用的基本概念 3.run命令的运行流程 4.为什么Docker比VM快 Docker架构图: 我们依照Docker架构图进行Docker基础概念的 ...

  3. 『现学现忘』Docker基础 — 32、通过DockerFile的方式挂载数据卷

    目录 1.简单了解一下DockerFile 2.通过DockerFile的方式挂载数据卷 (1)创建DockerFile文件 (2)编辑Dockerfile文件 (3)构建Dokcer镜像 (4)启动 ...

  4. 『现学现忘』Docker基础 — 34、DockerFile文件详解

    目录 1.DockerFile文件说明 2.Dockerfile构建过程解析 (1)Docker容器构建三步骤 (2)Dockerfile文件的基本结构 (3)Dockerfile注意事项 (4)Do ...

  5. 『现学现忘』Docker基础 — 35、实战:自定义CentOS镜像

    目录 1.前提说明 2.编写Dockerfile文件 3.构建镜像 4.运行镜像 5.列出镜像的变更历史 1)目标:自定义镜像wokong_centos. 2)所用到的保留字指令: FROM:基础镜像 ...

  6. 『现学现忘』Docker基础 — 10、Docker的安装

    目录 1.前提 2.通过yum安装Docker (1)更新yum包 (2)移除旧的Docker版本 (3)安装必须的软件包 (4)设置稳定yum源仓库 (5)更新yum软件包索引 (6)开始安装Doc ...

  7. 『现学现忘』Docker基础 — 30、Docker中数据卷相关命令

    目录 1.Volume命令说明 2.Volume命令的使用 (1)创建数据卷 (2)查看本地数据卷列表 (3)打印myVolume数据卷的详细信息 (4)删除数据卷 (5)删除所有未使用的数据卷 3. ...

  8. 『现学现忘』Docker基础 — 31、实现MySQL同步数据

    目录 1.搜索镜像 2.拉取镜像 3.查看镜像 4.启动镜像 5.操作容器 (1)在MySQL中创建数据库 (2)外部连接Dokcer容器中的MySQL服务 (3)查看挂载情况 (4)测试MySQL服 ...

  9. 『现学现忘』Docker基础 — 40、发布镜像到Docker Hub

    目录 1.准备工作 2.Docker登陆命令 3.Docker提交命令 4.总结: 5.补充:docker tag命令 1.准备工作 Docker Hub地址:https://hub.docker.c ...

随机推荐

  1. go基础——输入输出

    package main import ( "bufio" "fmt" "os" ) func main() { /* 输入和输出 fmt包 ...

  2. 从服务间的一次调用分析整个springcloud的调用过程(二)

    先看示例代码 @RestController @RequestMapping("/students") public class StudentController { @Auto ...

  3. 有手就行10——Jenkins+SonarQube代码审查

    有手就行10--Jenkins+SonarQube代码审查 Jenkins+SonarQube代码审查(1) - 安装SonarQube Jenkins+SonarQube代码审查(2) - 实现代码 ...

  4. pytest(10)-常用执行参数说明

    pytest单元测试框架中可以使用命令行及代码pytest.main()两种方式执行测试,且可以加入各种参数来组织执行测试.接下来我们来了解常用的执行参数的含义及其用法. pytest中的执行参数根据 ...

  5. git忽略文件权限检查

    如题  每个人本地设置不同 系统不同  环境不同  很有可能在团队开发的时候进行 不同文件权限的设置 但是如果大家都把这种权限的设置传上去 那么所有人的就都乱的 如果要去掉的话 第一步 进入这个项目的 ...

  6. 给博客加入链接安全跳转页(添加一个和CSDN一样的链接跳转页)

    本文首发于青云工作室 原文链接为 https://qystudio.ltd/posts/25250.html 前言 或是出于优化 SEO,或是出于加强网站体验,很多博客都给文章中的外部链接加上了个二次 ...

  7. docker安装、基本使用、实战(测试必备)

    Docker概念.作用.术语 一张超级形象的图 看到这张图,大家会想到什么? 可以这么理解:大海是操作系统,鲸鱼是Docker,集装箱是在Docker 运行的容器! 概念 百度百科:Docker 是一 ...

  8. 华为模拟器 AP AC配置

    组网示意图: 前提条件:1)所有设备工作正常2)依据上述组网建立测试环境 1)正确配置AC使AP发放SSID:'SSID-Temp1'.'SSID-Temp2'和'SSID-Temp3',且对应业务v ...

  9. [Python]数据类型、常量、变量和运算符(未完待续)

    标识符 一个ASCII标识符需要同时满足以下三个条件: 1.第一个字符必须是字母表中的字母或者下划线_ 2.标识符的其他部分由字母.数字.下划线组成 3.标识符对大小写是敏感的,即A与a是不同的 一般 ...

  10. Spark学习笔记(详细)

    Spark Core 第1章 Spark 概述 Spark是一种基于内存的快速.通用.可扩展的大数据分析计算引擎 Spark和Hadoop 的根本差异是多个作业之间的数据通信问题: Spark多个作业 ...