理解CMD 和 ENTRYPOINT 是如何互相作用的

2024-03-01 16:20

本文主要是介绍理解CMD 和 ENTRYPOINT 是如何互相作用的,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

官方文档: Dockerfile reference - Understand how CMD and ENTRYPOINT interact

目录

  • Understand how CMD and ENTRYPOINT interact
    • 官方文档原文
    • Docker run 覆写设置说明
      • 准备验证镜像 nginx:latest
      • 情景1: ENTRYPOINT 与 CMD均使用默认值
      • 情景2: ENTRYPOINT 与 CMD同时空值
      • 情景3: ENTRYPOINT有值 与 CMD为空值
      • 情景4: ENTRYPOINT 与 CMD 同时有值
      • 情景5: ENTRYPOINT为空值 与 CMD 有值
      • 情景6: ENTRYPOINT默认值 与 CMD 有值

Understand how CMD and ENTRYPOINT interact

理解CMD 和 ENTRYPOINT 是如何互相作用的

官方文档原文

Both CMD and ENTRYPOINT instructions define what command gets executed when running a container. There are few rules that describe their co-operation.

CMD和ENTRYPOINT指令都定义了运行容器时执行的命令。几乎没什么规则可以描述他们的合作关系。

  1. Dockerfile should specify at least one of CMD or ENTRYPOINT commands.

  2. ENTRYPOINT should be defined when using the container as an executable.

  3. CMD should be used as a way of defining default arguments for an ENTRYPOINT command or for executing an ad-hoc command in a container.

  4. CMD will be overridden when running the container with alternative arguments.

1. Dockerfile要求 CMD 与 ENTRYPOINT 两个命令中至少声明一个。
2.当容器是可执行时,应该定义 ENTRYPOINT。
3.CMD可被定义作为ENTRYPOINT命令的缺省参数或者在容器中执行的一个临时命令。
4.C当使用替代参数运行容器时,CMD将被覆盖

The table below shows what command is executed for different ENTRYPOINT / CMD combinations:

下表显示了针对不同ENTRYPOINT/CMD组合执行的命令:

在这里插入图片描述

说明上表中定义方式参见官方文档:Dockerfile reference - Shell and exec form

Note
If CMD is defined from the base image, setting ENTRYPOINT will reset CMD to an empty value. In this scenario, CMD must be defined in the current image to have a value.

如果基础镜像中定义了 CMD,设置了 ENTRYPOINT,会把 CMD 重置成空值。这种情况下,CMD必须在当前镜像定义一个值:

Docker run 覆写设置说明

上表中是个矩阵表,从两个维度组合CMD 和 ENTRYPOINT的命令。对应上述4条规则,验证docker run命令下使用情况。

官方文档: Running containers - Overriding image defaults

准备验证镜像 nginx:latest

  • 查看官方nginx:latest镜像的ENTRYPOINT 和 CMD 参数信息
    • “Entrypoint”: [
      /docker-entrypoint.sh
      ],
    • “Cmd”: [ “/bin/sh”,
      “-c”,
      "#(nop) ",
      “CMD [“nginx” “-g” “daemon off;”]
      ],
// nginx镜像已提前拉到本地
[root@centos7-10 ~]# docker image inspect nginx:latest 
[{"Id": "sha256:605c77e624ddb75e6110f997c58876baa13f8754486b461117934b24a9dc3a85","RepoTags": ["nginx:latest"],"RepoDigests": ["nginx@sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31"],"Parent": "","Comment": "","Created": "2021-12-29T19:28:29.892199479Z","Container": "ca3e48389f7160bc9d9a892d316fcbba459344ee3679998739b1c3cd8e56f7da","ContainerConfig": {
......"Cmd": ["/bin/sh","-c","#(nop) ","CMD [\"nginx\" \"-g\" \"daemon off;\"]"],"Image": "sha256:82941edee2f4d17c55563bb926387c3ae39fa1a99777f088bc9d3db885192209","Volumes": null,"WorkingDir": "","Entrypoint": ["/docker-entrypoint.sh"],......}}
]

情景1: ENTRYPOINT 与 CMD均使用默认值

  • 运行一个容器,ENTRYPOINT 和 CMD 均使用默认值
    1. docker run运行nginx:latest,
    2. 使用镜像 ENTRYPOINT 和 CMD 的默认值
    3. 查看容器的COMMAND,组合ENTRYPOINT 与 CMD 的默认值: “/docker-entrypoint.sh nginx -g ‘daemon off;’” ,CMD值作为ENTRYPOINT的命令参数。
[root@centos7-10 ~]# docker run -itd --rm nginx:latest 
514842c73f365f38f803252b9ee6b92d0665d7448c5a782dab7d1002671997b7
[root@centos7-10 ~]# docker ps -a --no-trunc 
CONTAINER ID                                                       IMAGE          COMMAND                                          CREATED          STATUS                      PORTS     NAMES
514842c73f365f38f803252b9ee6b92d0665d7448c5a782dab7d1002671997b7   nginx:latest   "/docker-entrypoint.sh nginx -g 'daemon off;'"   28 seconds ago   Up 26 seconds               80/tcp    stupefied_booth

情景2: ENTRYPOINT 与 CMD同时空值

  • 运行一个容器,ENTRYPOINT 和 CMD 同时空值的情况
    1. docker run运行nginx:latest,
    2. 覆写设置Entrypoint值为空。该设置操作会清空镜像默认CMD的值
    3. CMD为空值
    4. 容器运行禁止ENTRYPOINT 与 CMD 同时为空值,给出错误提示!
[root@centos7-10 ~]# docker run -it --entrypoint="" nginx:latest 
docker: Error response from daemon: No command specified.
See 'docker run --help'.

情景3: ENTRYPOINT有值 与 CMD为空值

  • 运行一个容器,ENTRYPOINT有值,CMD 为空值的情况
    1. docker run运行nginx:latest,
    2. 覆写设置Entrypoint=/bin/bash。该设置操作会清空镜像默认CMD的值
    3. CMD为空值
    4. 查看容器的COMMAND,显示ENTRYPOINT的值:“/bin/bash”
// 运行容器
[root@centos7-10 ~]# docker run -it --entrypoint /bin/bash nginx:latest 
root@d8f22cc19655:/# 
// 容器的COMMAND,显示 /bin/bash
[root@centos7-10 ~]# docker ps -a --no-trunc 
CONTAINER ID                                                       IMAGE          COMMAND       CREATED          STATUS          PORTS     NAMES
d8f22cc19655647798a7578dc9d07fd928388e3f575e18b0c4864d747f68c67d   nginx:latest   "/bin/bash"   36 seconds ago   Up 35 seconds   80/tcp    wonderful_shaw
[root@centos7-10 ~]# 

情景4: ENTRYPOINT 与 CMD 同时有值

  • 运行一个容器,ENTRYPOINT 与 CMD 均有值的情况
    1. docker run运行nginx:latest,
    2. 覆写设置Entrypoint=/bin/bash。该设置操作会清空镜像默认CMD的值
    3. 覆写设置CMD=“-c ls -a”
    4. 查看容器的COMMAND,组合ENTRYPOINT 与 CMD 的值: “/bin/bash -c ls -a” ,CMD值作为ENTRYPOINT的命令参数。
// 运行容器,--entrypoint /bin/bash,CMD -c ls -a 
[root@centos7-10 ~]# docker run -it --entrypoint /bin/bash nginx:latest -c ls -a 
bin  boot  dev  docker-entrypoint.d  docker-entrypoint.sh  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
// COMMAND /bin/bash -c ls -a
[root@centos7-10 ~]# docker ps -a --no-trunc 
CONTAINER ID                                                       IMAGE          COMMAND                CREATED          STATUS                      PORTS     NAMES
c3a03c567fac4133b803d66e330adb7bea31bdfdc1153eb8b9d0d5b2cbf6c15d   nginx:latest   "/bin/bash -c ls -a"   10 seconds ago   Exited (0) 9 seconds ago              clever_wilson

情景5: ENTRYPOINT为空值 与 CMD 有值

  • 运行一个容器,ENTRYPOINT为空值 与 CMD 有值的情况
    1. docker run运行nginx:latest,
    2. 覆写设置Entrypoint=“”。该设置操作会清空镜像默认CMD的值
    3. 覆写设置CMD=“/bin/bash -c ls -a”
    4. 查看容器的COMMAND,显示CMD的值: “/bin/bash -c ls -a”
// 运行容器,Entrypoint="",CMD /bin/bash -c ls -a
[root@centos7-10 ~]# docker run -it --entrypoint="" nginx:latest /bin/bash -c ls -a 
bin  boot  dev  docker-entrypoint.d  docker-entrypoint.sh  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
// COMMAND /bin/bash -c ls -a
[root@centos7-10 ~]# docker ps -a --no-trunc 
CONTAINER ID                                                       IMAGE          COMMAND                  CREATED              STATUS                          PORTS     NAMES
0261ca0bf5b1d802092da12f0d9339300e47e7cffd24b6e29b724a510adaec10   nginx:latest   "/bin/bash -c ls -a"     About a minute ago   Exited (0) About a minute ago             hopeful_hofstadter

情景6: ENTRYPOINT默认值 与 CMD 有值

  • 运行一个容器,ENTRYPOINT使用默认值 与 CMD 有值的情况
    1. docker run运行nginx:latest,
    2. 忽略设置Entrypoint,使用默认值为 “/docker-entrypoint.sh”
    3. 覆写设置CMD="nginx -v "
    4. 查看容器的COMMAND,组合ENTRYPOINT 与 CMD 的值: ** “/docker-entrypoint.sh nginx -v”** ,CMD值作为ENTRYPOINT的命令参数。
// 运行容器,CMD nginx -v
[root@centos7-10 ~]# docker run -itd nginx:latest nginx -v
94498d179a78b70ba8375b9a5348a7f68b3071991e418fc36f2eb3d0517e61c0
// COMMAND  "/docker-entrypoint.sh nginx -v"
[root@centos7-10 ~]# docker ps -a --no-trunc 
CONTAINER ID                                                       IMAGE          COMMAND                            CREATED          STATUS                      PORTS     NAMES
94498d179a78b70ba8375b9a5348a7f68b3071991e418fc36f2eb3d0517e61c0   nginx:latest   "/docker-entrypoint.sh nginx -v"   39 seconds ago   Exited (0) 38 seconds ago             kind_leavitt

这篇关于理解CMD 和 ENTRYPOINT 是如何互相作用的的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/763068

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们

分布式系统的个人理解小结

分布式系统:分的微小服务,以小而独立的业务为单位,形成子系统。 然后分布式系统中需要有统一的调用,形成大的聚合服务。 同时,微服务群,需要有交流(通讯,注册中心,同步,异步),有管理(监控,调度)。 对外服务,需要有控制的对外开发,安全网关。

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字