Dockerfile
因为Docker在C/S中运行。我们的本机是C,Docker引擎是S。实际的构建过程是在Docker引擎下完成的,因此此时无法使用本地文件。这需要将本地机器指定目录中的文件打包并提供给Docker引擎使用。
如果未指定最后一个参数,则默认上下文路径为Dockerfile的位置。
注意:不要将无用的文件放在上下文路径中,因为它们将被打包并发送到docker引擎。如果文件太多,进程将很慢。
COPY [--chown=<user>:<group>] <源路径1>... <目标路径>
COPY [--chown=<user>:<group>] ["<源路径1>",... "<目标路径>"]
Dockerfile是一个用于构建图像的文本文件。文本内容包含构建图像所需的说明和说明。
使用Dockerfile自定义图像
这里我只解释如何运行Dockerfile文件来定制图像。Dockerfile文件中的具体说明将在下一节中解释。在这里,您只需要了解施工过程。
1.接下来,定制一个nginx映像(构建的映像中会有一个/usr/share/nginx/html/index.html文件)
在空目录中,创建一个名为Dockerfile的新文件,并将以下内容添加到该文件中:
FROM centos
RUN yum -y install wget \
&& wget -O redis.tar.gz "http://download.redis.io/releases/redis-5.0.3.tar.gz" \
&& tar -xvf redis.tar.gz
添加
ADD指令的用例与COPY指令的用例相似(在相同的要求下,正式推荐COPY指令)。功能相似,但有以下区别:
ADD的优点:当<源文件>是tar压缩文件,并且压缩格式为gzip、bzip2和xz时,它将被自动复制并解压缩到<目标路径>。
ADD的缺点是:如果不解压tar压缩文件,就不可能复制它。映像生成缓存将无效,这可能会使映像生成变慢。是否使用它取决于是否自动解压缩。
命令
CMD <shell 命令>
CMD ["<可执行文件或命令>","<param1>","<param2>",...]
CMD ["<param1>","<param2>",...] # 该写法是为 ENTRYPOINT 指令指定的程序提供默认参数
与RUN指令类似,它用于运行程序,但两者在不同的时间点运行:
CMD在docker运行时运行。
RUN在Docker Build中。
函数:为启动的容器指定默认运行的程序。当程序运行时,容器结束。CMD指令中指定的程序可以被docker运行命令行参数中指定的要运行的程序覆盖。
注意:如果Dockerfile中有多条CMD指令,则只有最后一条指令生效。
集群管理
$ docker-machine create -d virtualbox swarm-manager
Docker Swarm是Docker的集群管理工具。它将Docker主机池转换为单个虚拟Docker主机。Docker Swarm提供了一个标准的Docker API。所有与Docker守护程序通信的工具都可以使用Swarm轻松扩展到多个主机。
支持的工具包括但不限于:
Dokku公司
Docker合成
Docker机器
詹金斯
道德原则
群集由管理节点和工作节点组成。
Swarm manager:负责整个集群的管理,包括集群配置、服务管理和其他与集群相关的工作。
工作节点:指图中可用的节点,主要负责运行相应的服务来执行任务。
Compose文件定义了两个服务:web和redis。
Web:此Web服务使用从Dockerfile当前目录构建的图像。然后将容器和主机绑定到暴露的端口5000。此示例服务使用Flask Web服务器的默认端口5000。
Redis:此Redis服务使用Docker Hub的公共Redis映像。
docker@swarm-manager:~$ docker service inspect --pretty helloworld
上下文:上下文路径。
Dockerfile:指定图像的Dockerfile文件名。
Args:添加一个构建参数,它是一个环境变量,只能在构建过程中访问。
标签:设置构造图像的标签。
目标:多层结构,可以指定哪个层。
配置加速器
在检查加速器是否有效并配置加速器后,如果图像拉动仍然非常缓慢,请手动检查加速器配置是否有效。在命令行上执行docker信息。如果从结果中看到以下内容,则配置成功。
$ docker info
Registry Mirrors:
某些网络应用程序可以在容器中运行。为了允许外部用户访问这些应用程序,可以通过-P或-P参数指定端口映射。
让我们通过港口连接到码头集装箱。
runoob@runoob:~$ docker ps
CONTAINER ID IMAGE COMMAND ... PORTS NAMES
33e4523d30aa training/webapp "python app.py" ... 0.0.0.0:5000->5000/tcp berserk_bartik
fce072cc88ce training/webapp "python app.py" ... 0.0.0.0:32768->5000/tcp grave_hopper
端口映射不是将Docker连接到另一个容器的唯一方法。
Docker有一个连接系统,允许多个容器连接在一起,共享连接信息。
Docker连接将创建父子关系,父容器可以在其中看到子容器的信息。
$ docker network create -d bridge test-net