十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
使用Docker怎么实现分布式应用功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
金秀网站建设公司成都创新互联,金秀网站设计制作,有大型网站制作公司丰富经验。已为金秀成百上千提供企业网站建设服务。企业网站搭建\成都外贸网站制作要多少钱,请找那个售后服务好的金秀做网站的公司定做!创建docker-compose.yml文件
创建docker-compose.yml文件,并放在与Dockerfile
相同的目录下,docker-compose.yml文件是一个YAML文件,它定义了Docker容器在生产中的行为方式。
version: "3" services: web: # 用你的用户名和镜像细节替换username/repo:tag命令 image: username/repo:tag deploy: replicas: 5 resources: limits: cpus: "0.1" memory: 50M restart_policy: condition: on-failure ports: - "80:80" networks: - webnet networks: webnet:
这个docker-compose.yml文件告诉Docker执行以下操作:
- 从注册表中取出我们在《Docker简单安装与应用入门教程》中上传的镜像。
- 运行该镜像的5个实例作为一个名为web的服务,限制每个服务器最多使用10%的CPU(跨所有核心)和50MB的RAM。
- 如果一个失败,立即重新启动容器。
- 将主机上的端口80映射到Web的端口80。
- 指示Web容器通过称为webnet的负载平衡网络共享端口80(在内部,容器本身将在临时端口上发布到Web的端口80)。
- 使用默认设置(这是一个负载平衡覆盖网络)定义webnet网络。
运行新的负载平衡应用程序
在使用docker stack deploy
命令之前,先运行以下命令。
$ docker swarm init
打开一个命令行终端,确保仍然在新目录的顶层,现在来运行它,必须给应用程序一个名称,在这里它被设置为getstartedlab
。
$ docker stack deploy -c docker-compose.yml getstartedlab
单个服务堆栈在一台主机上运行了5个部署镜像的容器实例,在应用程序中获取一项服务的服务ID。
$ docker service ls
您将看到Web服务的输出,并以您的应用程序名称作为前缀。如果您将其命名为与此示例中所示的相同,则名称将为getstartedlab_web。还列出了服务ID以及副本数量,镜像名称和暴露端口。
在服务中运行的单个容器称为任务。任务会被赋予唯一的数字增加的ID,最多可以运行在docker-compose.yml中定义的replicas数量。使用以下命令可以列出服务中的任务。
$ docker service ps getstartedlab_web
如果只列出系统上的所有容器,也会显示任务,但不会被服务过滤。
$ docker container ls -q
可以连续多次运行curl -4 http://localhost
,或者在浏览器中转到该URL并点击几次刷新。
无论哪种方式,都能看到容器ID的更改,演示负载平衡。在每个请求中,以循环方式选择5个任务中的一个来响应,容器ID将匹配您以前的docker container ls -q
命令的输出。
缩放应用程序
可以通过更改docker-compose.yml中的replicas值,保存更改并重新运行docker stack deploy
命令来扩展应用程序。
$ docker stack deploy -c docker-compose.yml getstartedlab
Docker会做一个更新操作,不需要先删除堆栈或杀死任何容器。现在,重新运行docker container ls -q
来查看重新配置的已部署实例。明显因为扩大了replicas值,即副本,有了更多的任务和容器。
接下来,结束应用程序和集群,使用docker stack rm
把应用程序结束,使用docker swarm leave
把集群结束。
$ docker stack rm getstartedlab $ docker swarm leave --force
看完上述内容,你们掌握使用Docker怎么实现分布式应用功能的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联成都网站设计公司行业资讯频道,感谢各位的阅读!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。