当项目需要使用Docker,对Dockerfile、配置加速器以及配置加速器的实际运用

举报
江南清风起 发表于 2024/08/14 22:05:52 2024/08/14
【摘要】 Dockerfile因为Docker在C/S中运行。我们的本机是C,Docker引擎是S。实际的构建过程是在Docker引擎下完成的,因此此时无法使用本地文件。这需要将本地机器指定目录中的文件打包并提供给Docker引擎使用。如果未指定最后一个参数,则默认上下文路径为Dockerfile的位置。注意:不要将无用的文件放在上下文路径中,因为它们将被打包并发送到docker引擎。如果文件太多,...

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
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。