Docker 入门之swarm部署web应用
笔者近期在利用的docker搭建一个swarm集群,目前的应用还是入门级的,读者可自行根据自己的需要修改自己需要部署的应用,今天笔者介绍的是一个web应用的swarm集群的搭建。看这篇文章之前,我希望读者把笔者前面两篇文章都认真搭建一遍,因为今天的应用主要是基于前面两篇文章的。
一,理解swarm集群
一个swarm是一组运行docker的机器加入到一个集群,这些机器可以是虚拟的也可以是物理的,这个集群中只有一个swarm管理者,其他的都是worker,它们统称为节点。
一个swarm管理者如何管理这些docker容器呢?这就涉及到swarm的调度方式。swarm有两种调度方式,一种是“emptiest node”即最大限度的利用每个机器,给一个机器尽可能的分配足够多的容器,另一种是“global”即确保每台机器至少运行一个容器。策略的选择可以通过改变docker-compose文件。
一个swarm管理者可以执行用户的命令,或者认证加入进来swarm集群的其他worker节点,而worker节点只提供他的计算或者存储等能力而不具备认证功能。如图

二,准备工作(在两台物理机上部署)
1,安装好docker compose组建。
2,按照我的上两篇文章将friendlyhello镜像运行成功并上传至自己的docker仓库(可选,如果没有,可以push我仓库中的镜像,我已经设置成public了,镜像名称是:sunshine99/ubuntu1.1,在下载前你需要登陆自己的docker帐号哦,运行 docker login 然后输入自己的用户和密码就好了)。
3,按照我上一篇文章的思路在本地调通了单主机的web应用。
4,两台主机需在同一个局域网下。
三,步骤
1,在任意一台主机上创建一个swarm管理者
docker swarm init --advertise-addr <ip>
(将ip替换成自己主机的ip地址即可)
仔细观察运行后的输出,它会告诉你其他主机加入这个swarm集群需要输入的命令,命令格式为:
docker swarm join --token <token> <ip>:<port>
一般而言,如果是在多台物理机上搭建swarm集群,那么port就是2377,如果是在docker虚拟机上搭建的,那么port就是2376。
2,在另外一台机器上运行上述命令的输出,若看到This node joined a swarm as a worker 恭喜你,最难的第一步已经创建成功。
3,部署自己的应用,我这里选取的是一个web应用,这个镜像已经在前面两篇文章中创建好了,这里我再贴一下这个docker-compose.yml文件。

将上述代码保存为docker-compose.yml,在manager节点的那台机器上运行
docker stack deploy -c docker-compose.yml getstartedlab
其中getstartedlab是我给这个web应用取得名字。
4,运行成功后你可以在manager节点的这台机器上输入命令进行验证查看
docker stack ps getstartedlab
5,在两台机器上分别访问该web网页。
在网页上输入创建manager节点时设定的ip即可。
至此,一个简单的web应用就部署在了swarm集群上了。完整的流程截图如下。


本文参考了docker官网文献。请勿转载。
Docker 入门之swarm部署web应用的更多相关文章
- docker入门3-docker swarm
swarm介绍 想要将应用部署在一个集群并运行在多台机器上? 通过将多台机器链接到"Dockerized"集群以实现应用程序运行在多容器,多机器的技术被称为swarm. 一个swa ...
- Docker管理工具 - Swarm部署记录
之前介绍了Docker集群管理工具-Kubernetes部署记录,下面介绍另一个管理工具Swarm的用法,Swarm是Docker原生的集群管理软件,与Kubernetes比起来比较简单. Swarm ...
- Docker容器使用jenkins部署web项目--总结(二)
(1)需要安装Docker容器,在Docker容器内安装jenkins,gogs,tomcat. 新建maven项目,添加findbugs plugin. 使用docker启动jenkins,go ...
- docker安装tomcat并部署web项目
docker安装tomcat就不说了,网上一大把 启动tomcat: docker run --name tomcat -p 8080:8080 -v $PWD/test:/usr/local/tom ...
- Docker 集群Swarm创建和Swarm Web管理
关于Docker Swarm更多的介绍请查看<Docker管理工具-Swarm部署记录> 一.环境配置 1.安装环境 # cat /etc/redhat-release CentOS Li ...
- docker入门4-docker stack
stack介绍 stack是一组共享依赖,可以被编排并具备扩展能力的关联service.举例来说就是在swarm那章描述docker层次架构时,说stack就是一个完整的服务--它可以由基于flask ...
- docker入门2-docker service
docker service介绍 service是生产环境中某个image的container集合.一个service只使用一个image,但它编排这个image的运行方式,比如使用哪个端口,根据需求 ...
- Docker入门系列1:简介
可以实现快速部署. 比如一台 16 核 32G 内存的虚拟机上,需要跑 500+ 个用户的应用(每个应用的功能可以认为是一个网站 + 一系列的 RESTful API),有两个事情很重要: 资源隔离: ...
- docker入门1-docker container
image和container介绍 一个image是一个可被docker执行的包,它包括程序运行的所有东西,包括代码,运行时,库,环境变量和配置文件. 一个container是image在内存中的运行 ...
随机推荐
- JDBC(一)
JDBC(Java DataBase Conectivity)Java数据库连接,是J2SE的一部分,由java.sql和javax.sql组成. package dbTest; import jav ...
- CF487 E. Tourists [点双连通分量 树链剖分 割点]
E. Tourists 题意: 无向连通图 C a w: 表示 a 城市的纪念品售价变成 w. A a b: 表示有一个游客要从 a 城市到 b 城市,你要回答在所有他的旅行路径中最低售价的最低可能值 ...
- Windows Server 2016-部署额外域控制器
我们一般所提到的所谓域外控制器,是指除域内第一台域控制器之外的其他域控制器.额外域控制器很多时候也有辅助域控一称.那么在同一域内安装多台域控制器有什么优点呢: 1.提高用户登录效率.多台域控制器可以同 ...
- 【翻译】CSS Animations VS the Web Animations API:案例学习
原文地址:CSS Animations vs the Web Animations API: A Case Study May 03, 2017 css, javascript 上周我写了我如何使用C ...
- nodejs事件循环
1. 只有一个主线程,node开始执行脚本时,会先进事件循环初始化(同步任务,发出异步请求,规划定时器生效时间,执行promise.nextTick等),这是事件循环还未开始. 2. nodejs每一 ...
- Function与Object的关系
这里先简单介绍一下我研究这个问题的初衷.起初我只是想研究一下原型链的基本思想.构造函数拥有prototype属性,指向它的prototype,而该构造函数的实例化对象则拥有一个[[prototype] ...
- MySQL创建带有编码的数据库
mysql> create database chao default character set utf8 collate utf8_general_ci;
- 织梦autoindex应用 dedecms循环中判断第几条数据
arclist 标签下使用 [field:global.autoindex/] 默认从1开始 {dede:arclist row='10' titlelen='48' typeid='1' chann ...
- Redis进阶实践之十二 Redis的Cluster集群动态扩容
一.引言 上一篇文章我们一步一步的教大家搭建了Redis的Cluster集群环境,形成了3个主节点和3个从节点的Cluster的环境.当然,大家可以使用 Cluster info 命令查看Cl ...
- .NET平台开源项目速览(20)Newlife.Core中简单灵活的配置文件
记得5年前开始拼命翻读X组件的源码,特别是XCode,但对Newlife.Core 的东西了解很少,最多只是会用用,而且用到的只是九牛一毛.里面好用的东西太多了. 最近一年时间,零零散散又学了很多,也 ...