云计算-7-Dockerfile深度解析CMD和ENTRYPOINT指令

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 云计算-7-Dockerfile深度解析CMD和ENTRYPOINT指令

云计算-7-Dockerfile深度解析

CMD

CMD指令


Docker不是虚拟机,Docker镜像启动后就是容器,容器是进程,启动的时候需要指定运行的程序和参数,CMD指令的作用就是用于指定容器进程启动命令,其格式和我们之前在云计算-6-Dockerfile制作镜像中介绍的RUN指令很相似,有两种格式,三种写法:


shell格式:CMD command arg1 arg2


exec格式:CMD [“可执行文件”,“arg1”,“arg2”]


CMD [“agr1”,“arg2”],为 ENTRYPOINT 提供默认参数

例子1

vi mynginx



文件dockerfile内容

FROM nginx:1.21.6RUN echo '<h1>Welcome My Docker!</h1>' > /usr/share/nginx/html/index.htmlCMD echo 'hello docker'


打包镜像

docker build -t mynginx:v3  -f /root/mynginx_3 .


运行镜像

docker run -it --name mynginx_3 -p 8083:80  mynginx:v3


结果

:如果添加**-d**,

docker run -it --name mynginx_3 -p 8083:80 -d mynginx:v3

0c91457d3a1a9de63438c845a2316d94.png


我们可以使用,docker logs查看容器日志

docker logs mynginx_3
• 1

结果为



例子2

我们使用以centos为基础镜像,使用yum的方式构建nginx,Dockerfile的进步如下:

FROM centosRUN cd /etc/yum.repos.d/ RUN sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*RUN sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-*RUN yum clean allRUN yum install -y yum-utilsRUN yum install -y nginxRUN echo 'hello world' > /usr/share/nginx/html/index.htmlEXPOSE 80CMD ["/usr/sbin/nginx", "-g","daemon off;"]


  • 打包镜像
docker build -t mynginx:v1 .
• 1
  • 运行镜像
docker run -it --name mynginx_1  -p 8080:80 -d  mynginx:v1


查看结果

提示:

很多人在上面的Dockerfile中经常将cmd写为

CMD service nginx start

然后发现容器执行后立即退出了,甚至还在容器中使用systemctl命令,然后发现这个命令执行不了,这主要是没有分清楚前后台概念,没有区分容器和虚拟机的差异

对于容器,他启动程序就是容器的应用进程,容器就是为主进程存在的,主进程退出,容器就也退出了。


如果使用 CMD service nginx start 实际上就是使用

CMD ['sh','-c','service nginx start']



主进程实际上就是sh,当service nginx start命令结束, sh主进程也就结束了,容器自然就退出了。

ENTRYPOINT

ENTRYPOINT指令


ENTRYPOINT的格式和RUN的指令是一样的,分为 exec 格式和 shell 格式:


shell格式:command param1 param2 (shell 形式)


exec格式:ENTRYPOINT [“executable”, “param1”, “param2”] ( exec 方式, 首选方式)


ENTRYPOINT目的和CMD一样,都是在指定容器启动程序和启动程序的参数,在运行时参数可以替代

例子3

FROM centosRUN cd /etc/yum.repos.d/RUN sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*RUN sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-*RUN yum clean allRUN yum install -y yum-utils#RUN yum makecache fastRUN yum install -y nginxRUN echo 'hello world' > /usr/share/nginx/html/index.htmlEXPOSE 80ENTRYPOINT ["/usr/sbin/nginx","-g","daemon off;"]


如果我们启动nginx的时候想查看nginx的版本

此处的-v,就是nginx -v。


当指定了 ENTRYPOINT 后,CMD 的含义就发生了改变,不再是直接的运行其命令,而是将 CMD 的内容作为参数传给 ENTRYPOINT 指令,换句话说实际执行时,将变为:

<ENTRYPOINT> "<CMD>"



例子四

FROM centosRUN cd /etc/yum.repos.d/RUN sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*RUN sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-*RUN yum clean allRUN yum install -y yum-utils#RUN yum makecache fastRUN yum install -y nginxRUN echo 'hello world' > /usr/share/nginx/html/index.htmlEXPOSE 80CMD ["-g","daemon off;"]ENTRYPOINT ["/usr/sbin/nginx"]


实际例子4含义和例子三是一样的。


提示

只能有一个CMD


  • Dockerfile中只能有一条CMD指令。如果您列出多个CMD,则只有最后一个CMD才会生效。
  • CMD的主要目的是为执行中的容器提供默认值。这些默认值可以包含可执行文件,也可以省略可执行文件,在这种情况下,您还必须指定ENTRYPOINT指令。


CMD为ENTRYPOINT提供默认参数


  • 如果使用CMD为ENTRYPOINT指令提供默认参数,则CMD和ENTRYPOINT指令均应使用JSON数组格式指定。

docker run启动参数会覆盖CMD内容

# 一个示例 FROM alpine LABEL maintainer=leifengyang CMD ["1111"] ENTRYPOINT ["echo"] #构建出如上镜像后测试 docker run xxxx:什么都不传则 echo 1111echo 1111 docker run xxx arg1:传入arg1 则echo arg1


目录
相关文章
|
19天前
|
存储 应用服务中间件 云计算
深入解析:云计算中的容器化技术——Docker实战指南
【10月更文挑战第14天】深入解析:云计算中的容器化技术——Docker实战指南
46 1
|
1月前
|
JSON JavaScript 前端开发
Javaweb中Vue指令的详细解析与应用
Vue指令提供了一种高效、声明式的编码方式,使得开发者可以更专注于数据和业务逻辑,而不是DOM操作的细节。通过熟练使用Vue指令,可以极大地提高开发效率和项目的可维护性。
19 3
|
2月前
|
JavaScript 前端开发 UED
Javaweb中Vue指令的详细解析与应用
Vue指令是Vue框架中非常强大的特性之一,它提供了一种简洁、高效的方式来增强HTML元素和组件的功能。通过合理使用这些指令,可以使你的JavaWeb应用更加响应用户的操作,提高交互性和用户体验。而且,通过创建自定义指令,你可以进一步扩展Vue的功能,使其更贴合你的应用需求。
18 1
|
27天前
|
云计算 开发者 Docker
揭秘云计算中的容器化技术——Docker的深度解析
【10月更文挑战第6天】揭秘云计算中的容器化技术——Docker的深度解析
|
3月前
|
存储 算法 Java
Java中的集合框架深度解析云上守护:云计算与网络安全的协同进化
【8月更文挑战第29天】在Java的世界中,集合框架是数据结构的代言人。它不仅让数据存储变得优雅而高效,还为程序员提供了一套丰富的工具箱。本文将带你深入理解集合框架的设计哲学,探索其背后的原理,并分享一些实用的使用技巧。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往高效编程的大门。
|
3月前
|
存储 边缘计算 安全
边缘计算与云计算的协同工作:技术解析与应用前景
【8月更文挑战第4天】边缘计算与云计算的协同工作是未来信息技术发展的重要趋势。通过合理地分配任务和资源,两者可以相互补充、发挥各自的优势,实现更高效的数据处理和分析。这种协同模式不仅提高了系统的性能和可靠性,还满足了复杂多变的应用需求,为人工智能、物联网等技术的发展提供了强有力的支持。
205 11
|
3月前
|
自然语言处理 计算机视觉 Python
VisProg解析:根据自然语言指令解决复杂视觉任务
VisProg是一个神经符号系统,能够根据自然语言指令生成并执行Python程序来解决复杂的视觉任务,提供可解释的解决方案。
44 0
|
4月前
|
弹性计算 负载均衡 网络协议
云计算中的弹性伸缩与负载均衡技术解析
【7月更文挑战第4天】弹性伸缩与负载均衡作为云计算平台中的两大关键技术,对于构建高可用、可扩展的应用系统具有重要意义。通过合理利用这两种技术,企业可以灵活应对不断变化的业务需求,降低运营成本,提高资源利用效率。未来,随着技术的不断进步和应用的深入,弹性伸缩与负载均衡技术将在更多领域发挥重要作用,推动云计算技术的持续发展。
|
26天前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
60 0
|
26天前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
49 0

热门文章

最新文章

推荐镜像

更多