Dockerfile中的CMD和ENTRYPOINT

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: **Dockerfile 中的 `CMD` 和 `ENTRYPOINT` 用于设定容器启动行为。`CMD` 提供默认命令,可被 `docker run` 覆盖;`ENTRYPOINT` 设置不可变的入口点,其参数与 `CMD` 结合使用。两者皆有两种语法格式:数组和字符串。`ENTRYPOINT` 与 `CMD` 结合允许用户覆盖默认参数,但若需替换 `ENTRYPOINT`,需使用 `--entrypoint`。**

在 Dockerfile 中,CMDENTRYPOINT 命令都用于指定容器启动时要执行的命令或可执行文件,但它们之间存在一些重要的区别。

CMD 命令

CMD 命令用于为容器指定默认的命令和参数。在一个 Dockerfile 中,通常只会有一个 CMD 命令,它可以有多个参数,这些参数通常是要执行的命令及其参数。当你使用 docker run 启动容器时,如果没有提供要运行的命令,Docker 会使用 CMD 中的命令作为默认命令来启动容器。

CMD 命令的语法有两种:

  1. 使用字符串数组的形式:

Dockerfile

  1. 复制代码
CMD ["executable","param1","param2"]
  1. 使用字符串的形式:

Dockerfile

  1. 复制代码
CMD command param1 param2

如果你在 Dockerfile 中指定了多个 CMD 命令,只有最后一个 CMD 命令会生效。

示例:

Dockerfile

复制代码

# 使用字符串数组形式
CMD ["python", "app.py"]

# 使用字符串形式
# CMD python app.py

在这个示例中,如果你不在 docker run 命令中提供要运行的命令,容器将默认运行 python app.py

ENTRYPOINT 命令

ENTRYPOINT 命令用于配置容器的入口点可执行文件或命令。与 CMD 不同,ENTRYPOINT 命令的参数不会被覆盖,而是作为容器启动时运行的主要命令。你可以将 ENTRYPOINT 命令与 CMD 命令结合使用,以为容器提供默认参数。

ENTRYPOINT 命令的语法也有两种:

  1. 使用字符串数组的形式:

Dockerfile

  1. 复制代码
ENTRYPOINT ["executable","param1","param2"]
  1. 使用字符串的形式:

Dockerfile

  1. 复制代码
ENTRYPOINT command param1 param2

CMD 不同,ENTRYPOINT 命令的参数不会被忽略,而是会被传递给 ENTRYPOINT 命令所指定的可执行文件或命令。

示例:

Dockerfile

复制代码

# 使用字符串数组形式
ENTRYPOINT ["python", "app.py"]

# 使用字符串形式
# ENTRYPOINT python app.py

在这个示例中,如果你在 docker run 命令中提供了额外的参数,例如 docker run my-container arg1 arg2,这些额外的参数会被传递给 python app.py

总结:

  • CMD 用于指定容器启动时默认要执行的命令,但可以被 docker run 命令中的命令覆盖。
  • ENTRYPOINT 用于指定容器的入口点命令或可执行文件,参数不会被覆盖,而是会与 CMD 结合使用,提供默认参数。如果在 docker run 命令中提供了额外的参数,它们会被附加到 ENTRYPOINT 后面。

组合使用

CMDENTRYPOINT 可以结合使用,这意味着 CMD 中的命令参数将会被传递给 ENTRYPOINT 中指定的命令或可执行文件。这样的结合可以使容器更灵活,允许用户在运行容器时覆盖 CMD 中的默认参数。

下面是一个示例,演示了如何在 Dockerfile 中结合使用 CMDENTRYPOINT

Dockerfile

复制代码

# 使用 ENTRYPOINT 指定默认的可执行文件
ENTRYPOINT ["echo", "Hello,"]

# 使用 CMD 指定默认的参数
CMD ["world!"]

在这个示例中,ENTRYPOINT 指定了默认的可执行文件为 echo,而 CMD 指定了默认的参数为 "world!"。当你运行容器时,可以覆盖 CMD 中的参数,例如:

bash

复制代码

docker run my-container "Goodbye!"

运行上述命令后,容器将输出:

复制代码

Hello, Goodbye!

注意以下几点:

  1. CMD 中的参数可以被 docker run 命令中的参数覆盖,但 ENTRYPOINT 中的参数不会被覆盖。
  2. 如果在 docker run 命令中不提供任何额外的参数,容器将执行 ENTRYPOINT 中指定的命令,并使用 CMD 中的参数作为默认参数。
  3. 如果你希望完全替换 ENTRYPOINT 中的命令而不是附加参数,可以在 docker run 命令中使用 --entrypoint 选项,例如:

bash

复制代码

docker run --entrypoint /bin/sh my-container

这将使用 /bin/sh 作为新的 ENTRYPOINT 命令,忽略掉 CMD 中的参数。

总结

  1. CMD 指令
  • 定义容器启动时的默认命令和参数。
  • 如果 docker run 时没有指定命令,将使用 CMD 指定的命令。
  • Dockerfile 中只能有一个有效的 CMD 指令,多个 CMD 的情况下,只有最后一个会生效。
  • 有两种语法形式:数组形式(推荐)和字符串形式。
  1. ENTRYPOINT 指令
  • 配置容器的入口点命令或可执行文件。
  • ENTRYPOINT 的参数不会被覆盖,而是作为容器启动的主命令。
  • 也有两种语法形式:数组形式(推荐)和字符串形式。
  • 可以与 CMD 结合使用,CMD 中的参数将作为 ENTRYPOINT 的附加参数。
  1. CMD 和 ENTRYPOINT 的组合
  • 这种组合增加了灵活性,允许用户覆盖 CMD 的默认参数。
  • ENTRYPOINT 指定执行文件,CMD 提供默认参数。
  • 如果 docker run 时指定了参数,它们会覆盖 CMD 的参数,但不会影响 ENTRYPOINT
  1. 替换 ENTRYPOINT
  • 使用 docker run 命令的 --entrypoint 选项可以完全替换 Dockerfile 中定义的 ENTRYPOINT

转载来源:https://juejin.cn/post/7317882649275580468

相关文章
|
Linux Docker 容器
CentOS7离线安装Docker
CentOS7离线安装Docker
2243 0
|
Web App开发 域名解析 缓存
如何在 Ubuntu 20.04 上安装 Node.js 和 npm
本文我们主要为大家介绍在 Ubuntu 20.04 上安装 Node.js 和 npm 的三种不同的方式。
162315 7
如何在 Ubuntu 20.04 上安装 Node.js 和 npm
|
存储 关系型数据库 MySQL
DataX: 阿里开源的又一款高效数据同步工具
DataX 是由阿里巴巴集团开源的一款大数据同步工具,旨在解决不同数据存储之间的数据迁移、同步和实时交换的问题。它支持多种数据源和数据存储系统,包括关系型数据库、NoSQL 数据库、Hadoop 等。 DataX 提供了丰富的数据读写插件,可以轻松地将数据从一个数据源抽取出来,并将其加载到另一个数据存储中。它还提供了灵活的配置选项和高度可扩展的架构,以适应各种复杂的数据同步需求。
|
Kubernetes 网络协议 调度
在K8S中,如何具体实现Pod的IP地址发生变化时,不影响正常服务使用?
在K8S中,如何具体实现Pod的IP地址发生变化时,不影响正常服务使用?
|
5月前
|
机器学习/深度学习 JSON 监控
国内最大的MCP中文社区来了,4000多个服务等你体验
国内最大的MCP中文社区MCPServers来了!平台汇聚4000多个服务资源,涵盖娱乐、监控、云平台等多个领域,为开发者提供一站式技术支持。不仅有丰富的中文学习资料,还有详细的实战教程,如一键接入MCP天气服务等。MCPServers专注模块稳定性和实用性,经过99.99% SLA认证,是高效开发的理想选择。立即访问mcpservers.cn,开启你的开发之旅!
6343 16
|
5月前
|
存储 缓存 文件存储
uv安装python及其依赖的加速方法
国内在使用uv的时候,可能会涉及到装python的速度太慢的问题,为了解决这个问题,可以使用`UV_PYTHON_INSTALL_MIRROR`这个环境变量。除此以外,对于多人协作场景,`UV_CACHE_DIR`也是一个有用的环境变量。本文会介绍这两个变量。
4266 10
|
域名解析 Kubernetes 负载均衡
在K8S中,外部访问容器服务,比如说提供了一个域名,链路怎么走?数据经过哪些组件?
在K8S中,外部访问容器服务,比如说提供了一个域名,链路怎么走?数据经过哪些组件?
|
11月前
|
JSON 运维 Kubernetes
|
存储 负载均衡 Cloud Native
【专栏】Minio是一款高性能分布式对象存储服务,以其易用性和可扩展性著称
【4月更文挑战第28天】Minio是一款高性能分布式对象存储服务,以其易用性和可扩展性著称,适用于存储多媒体内容。通过组建Minio集群,可实现高可用性、高性能、可扩展性和数据保护。搭建集群包括安装Minio、配置集群参数、启动节点、验证集群状态、设置访问权限及可选的数据迁移步骤。Minio集群是实现可靠且高性能存储解决方案的理想选择,适合各种应用场景。
759 0
|
网络协议 安全 Linux
Linux的netns使用总结
Linux的netns(Network Namespace)是一项强大的网络隔离功能,可在内核层面创建多个独立的网络空间,每个空间配备独立的网络协议栈,包括接口、路由表及iptables规则等,确保不同应用或服务在网络环境中互不干扰,提升系统安全性和灵活性。通过`ip netns`命令可轻松管理netns,实现创建、删除及执行命令等功能。netns适用于容器技术、虚拟化环境及网络测试等多种场景,为用户提供高效、安全的网络环境管理方案。
829 3