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

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 当项目需要使用Docker,对Dockerfile、配置加速器以及配置加速器的实际运用

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
相关文章
kde
|
4月前
|
Kubernetes 关系型数据库 文件存储
手把手教你完成极空间 NAS Docker 镜像加速配置
本教程详细介绍了如何在极空间NAS上配置轩辕镜像加速器,以提升Docker镜像的下载速度与稳定性。内容涵盖账号注册、网络确认、加速器设置及验证方法,并提供常见问题解决方案,帮助用户高效完成容器化应用部署。
kde
1427 1
|
7月前
|
Prometheus 监控 Cloud Native
Prometheus配置docker采集器
本文介绍了如何使用 Prometheus 监控 Docker 容器,涵盖环境准备、配置文件编写及服务启动等步骤。首先确保安装 Docker 和 Docker Compose,接着通过 `docker-compose.yml` 配置 Prometheus 和示例应用。创建 `prometheus.yml` 指定数据采集目标,最后用 `docker-compose up -d` 启动服务。文章还展示了甘特图和类图,帮助理解服务状态与关系,助力提升系统可靠性和可维护性。
240 11
kde
|
4月前
|
文件存储 数据安全/隐私保护 开发者
群晖NAS Docker镜像源加速配置教程
本教程介绍了群晖NAS用户如何通过配置轩辕镜像加速服务提升Docker镜像拉取速度。内容包括配置前准备、详细设置步骤及日常使用说明,帮助用户快速完成配置并享受高效稳定的镜像下载体验。
kde
2700 59
kde
|
Docker 容器 文件存储
飞牛fnOS Docker镜像加速配置全攻略
本文介绍了如何在飞牛fnOS中配置Docker镜像加速服务,通过设置轩辕镜像仓库加速器,提升镜像拉取速度与稳定性。内容涵盖配置前准备、加速源设置、首选加速源调整及使用指南,帮助用户高效完成镜像操作。
kde
1852 56
|
4月前
|
Java 分布式数据库 Docker
使用Docker配置并连接HBase的Java API
本流程概要的解释了如何在Docker上配置并启动HBase服务,并通过Java API进行连接和操作表,不涉及具体的业务逻辑处理和数据模型设计,这些因应用而异需由开发者根据实际需求进行实现。
209 13
|
5月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
569 4