理解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

相关文章

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Java 继承和多态的作用及好处

《Java继承和多态的作用及好处》文章讲解Java继承与多态的概念、语法及应用,继承通过extends复用父类成员,减少冗余;多态实现方法重写与向上转型,提升灵活性与代码复用性,动态绑定降低圈复杂度... 目录1. 继承1.1 什么是继承1.2 继承的作用和好处1.3 继承的语法1.4 子类访问父类里面的成

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

SpringBoot 中 CommandLineRunner的作用示例详解

《SpringBoot中CommandLineRunner的作用示例详解》SpringBoot提供的一种简单的实现方案就是添加一个model并实现CommandLineRunner接口,实现功能的... 目录1、CommandLineRunnerSpringBoot中CommandLineRunner的作用