• 作者:老汪软件技巧
  • 发表时间:2024-12-29 11:04
  • 浏览量:

作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。

查看容器启动参数_容器启动过程_

我们在上一章,讲了虚拟化,虚拟化是把硬件虚拟化,然后创建出来的虚拟机完全隔离,而Docker则是软件(内核)虚拟化,他的隔离性会低于虚拟机。我们将通过3-4周来讲解Docker相关内容,由于涉及到内容较多,就不一一列出来具体的细节,主要从以下几个方面来讲解:

Docker基本情况

Docker基本命令

Dockerfile(本小节属于)

Docker镜像

Docker仓库

Docker原理

Docker网络&存储&日志

Docker-Compose

Docker番外篇

前面讲的Dockerfile里面的参数相对功能比较固定,也不存在覆盖的问题,相对都比较简单,只要理解对应的逻辑即可。

今天要讲的最后2个参数CMD和ENTRYPOINT都是容器的启动参数,我们前面也讲过,如果没有前台进程,容器是无法启动成功的。CMD和ENTRYPOIN他们的作用是一样的,每个参数都有2个写法,他们之间还有覆盖关系,而且docker run的时候注入的参数也会存在注入和覆盖的关系。

两种写法Shell

等同于sh -c ping 127.0.0.1

例如:

<code class="hljs language-css" lang="css">FROM centos:7
CMD ping 127.0.0.1

查看容器启动参数_容器启动过程_

Exec(推荐方式)

等同于ping 127.0.0.1

例如:

FROM centos:7
ENTRYPOINT ["ping", "127.0.0.1"]

查看容器启动参数_容器启动过程_

异同1.CMD参数被覆盖

FROM centos:7
CMD ["ping", "127.0.0.1"]

查看容器启动参数__容器启动过程

_容器启动过程_查看容器启动参数

容器启动过程__查看容器启动参数

2.ENTRYPOINT参数未被覆盖

FROM centos:7
ENTRYPOINT ["ping", "127.0.0.1"]

这里容器启动失败,是因为ENTRYPOINT参数不会被覆盖,但是docker run的命令会作为ENTRYPOINT的参数传递进去就启动命令就变成

ping 127.0.0.1 ping 127.0.0.1 

而这个启动参数组合到一起就变成了错误参数无法启动。

传入正确的参数,则可以正常启动,启动参数就变成

ping  127.0.0.1 -I 127.0.0.1

容器启动过程_查看容器启动参数_

3.同时存在CMD和ENTRYPOINT

下面2个操作和我曾经的记忆出现了一点偏差。

3.1 这个写法是CMD未生效

FROM centos:7
CMD ping 127.0.0.1
ENTRYPOINT ping 192.168.31.204

_容器启动过程_查看容器启动参数

3.2 这个写法是CMD作为ENTRYPOINT的参数

FROM centos:7
CMD ["127.0.0.1"]
ENTRYPOINT ["ping"]

_容器启动过程_查看容器启动参数

经过我们我们上面的例子,我们应该基本上掌握了如何给自己的容器编写合适的Dockerfile,当然实际上我们可能用不上这么复杂的逻辑,但是掌握了这些知识,则会加强对Docker的理解和排错,后面我们将创建几个需求来然后来编写具体的Docker。

运维小路

一个不会开发的运维!一个要学开发的运维!一个学不会开发的运维!欢迎大家骚扰的运维!