阿里云服务器部署?Docker?Swarm集群_docker

来源:脚本之家  责任编辑:小易  
目录
一、什么是 Docker Swarm?二、Docker Swarm 和 k8s的区别三、购买4台阿里云服务器四、Docker Swarm 工作模式五、部署 Docker Swarm 集群?连接4台服务器?安装Docker??部署Swarm六、Raft协议七、其它命令???Docker Stack???Docker Secret??Docker Config?小结

一、什么是 Docker Swarm?

Swarm是Docker公司推出的用来管理docker集群的平台,几乎全部用GO语言来完成的开发的,代码开源在https://github.com/docker/swarm, 它是将一群Docker宿主机变成一个单一的虚拟主机,Swarm使用标准的Docker API接口作为其前端的访问入口,换言之,各种形式的DockerClient(compose,docker-py等)均可以直接与Swarm通信,甚至Docker本身都可以很容易的与Swarm集成,这大大方便了用户将原本基于单节点的系统移植到Swarm上,同时Swarm内置了对Docker网络插件的支持,用户也很容易的部署跨主机的容器集群服务。

Docker Swarm 的作用就是用来管理Docker集群的平台

二、Docker Swarm 和 k8s的区别

Swarm的优势 与 劣势

优势

swarm API兼容docker API,使得swarm 学习成本低,同时架构简单,部署运维成本较低。

劣势

同样是因为API兼容,无法提供集群的更加精细的管理。在网络方面,默认的Docker 容器是通过桥接与NAT和主机外通信的,这就出现了2个问题,一个是因为NAT,外部主机无法主动访问容器内(除了端口映射) ,另外默认桥接IP是一样的,这样会出现不同主机之间又相同的IP的情况,可以通过其它工具解决。容器可靠性方面无K8S的 Replication Controllers 可以监控并维持容器的声明。swarm在启动时刻可以控制容器启动,启动后,如果容器崩溃,swarm没有机制来保证容器的运行

K8S的优势与劣势

优势

容器的高可用性,集群的精密管理,复杂的网络场景

劣势

K8S的学习曲线陡峭,同时运维的成本相对高点

一般来说,服务不超过10个采用swarm即可,超过10个后必须采用K8S来保证集群的高可用与高可靠性!

三、购买4台阿里云服务器

我们选择按量付费,否则单独购买服务器的话很贵,按量付费用完即可释放,轻松便捷~

注意:购买需要向阿里云服务器充值100元,否则无法进行按量付费

创建实例

阿里云官方购买服务器

进入如下界面,选择按量付费

选择购买机器的类型 1V 2G 即可

选择镜像

进入下一步网络和安全组设置,保持默认即可,带宽可拉满(不收费)

设置您的密码

下一步,默认即可,确认订单,完成购买服务器操作

单击创建实例即可完成操作!

四、Docker Swarm 工作模式

Docker Engine 1.12 引入了 swarm 模式,使您能够创建一个由一个或多个 Docker 引擎组成的集群,称为 swarm。一个 swarm 由一个或多个节点组成:在 swarm 模式下运行 Docker Engine 1.12 或更高版本的物理机或虚拟机。

有两种类型的节点:管理器工作器

五、部署 Docker Swarm 集群

?连接4台服务器

我们采用 XShell 进行连接阿里云ECS服务器

输入了之后会提示输入用户名和密码,输入即可成功连接

?安装Docker

这里我们采用4台服务器同时操作,否则一台一台的安装太浪费时间了,如下

这样就是一个窗口输入命令其它窗口同步,高效率完成~

具体安装Docker可看:Docker安装阿里云服务器和在虚拟机安装遇到的坑(问题小结)

??部署Swarm

Docker安装完毕后,开始部署我们的集群,Docker自带Swarm,所以我们直接部署即可

初始化节点

docker swarm init --help 

获取网络地址,进行创建节点

ip addr
docker swarm init --advertise-addr 39.96.185.143

获取令牌

# 管理节点
docker swarm join-token manager
# 工作节点
docker swarm join-token worker

--token 后面的 是要利用上面的命令生成的,不是我的固定的,需要去生成,后续端口根据你的ip地址来~

我们其它机器加入节点

docker swarm join --token SWMTKN-1-1mzq8iev00xgswszp91h18tspm9rl5py7upw6ri9iaw484a1b3-4f159n0ky1bcsnqlkkohx0g1a 172.27.206.16:2377

第一台机器可查看是否成功加入

docker node ls

最后一台机器可设置为管理节点

docker swarm join --token SWMTKN-1-1mzq8iev00xgswszp91h18tspm9rl5py7upw6ri9iaw484a1b3-a795z02iuctnhf4izji1fmmiv 172.27.206.16:2377

成功搭建集群~

六、Raft协议

双主双从:假设一个主节点挂了,那么其它节点是否可以使用

Raft协议:保证了大多数节点存活可以使用,只要 > 1,集群至少大于3台

将主节点停止后,其它节点会宕机,无法使用!

无法查看节点信息

Raft协议是必须保证大多数节点存活,才可以达到高可用,否则不可用!

七、其它命令

???Docker Stack

部署集群项目的方式

# 单机部署
docker-compose
# 集群部署
docker stack
# 单机
docker-compose up 
# 集群
docker stack deploy

???Docker Secret

Docker Secret 是安全证书,用来配置密码与证书

docker secret --help

??Docker Config

Docker Config 是配置

docker config --help

?小结

以上就是【Bug 终结者】对 【云原生】阿里云服务器部署 Docker Swarm集群 的简单介绍,部署 Docker 集群,在微服务架构不超过10个的情况下会采用Docker Swarm或Compose 部署项目,如果超过的话,需要去适用K8S 来部署我们的项目上线! 后续会更新 K8S 相关文章,Docker 已完结!

到此这篇关于阿里云服务器部署 Docker Swarm集群的文章就介绍到这了,更多相关阿里云Docker Swarm集群内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

您可能感兴趣的文章:阿里云部署Docker私有镜像仓库的实现步骤docker部署crownblog项目到阿里云的方法步骤Docker镜像的制作,上传,拉取和部署操作(利用阿里云)阿里云esc服务器Docker部署单节点Mysql的讲解

  • 本文相关:
  • centos7 安装docker 解决启动不了的问题
  • 详解centos7 docker1.12安装私有仓库
  • docker-修改容器挂载目录的3种方法小结
  • 详解docker pull 下来的镜像都存到了哪里
  • docker容器配置nginx实例分享
  • docker 数据卷及数据容器详细介绍及示例
  • docker?mysql5.7如何设置不区分大小写
  • idea集成docker实现远程部署的步骤
  • centos7 安装jenkins详细介绍
  • ubuntu16.04docker的cs模式详细介绍
  • 阿里云如何部署Linux云服务器实例环境
  • 怎么在阿里云服务器部署多个tomcat
  • 如何在阿里云服务器部署Django
  • 怎么在阿里云服务器上用IIS部署多个织梦系统,我想部署多个网...
  • 阿里云服务器部署网站为什么会自动显示google广告
  • 阿里云服务器如何部署ERP,有公网ip吗
  • 阿里云服务器如何布署ERP,有公网ip吗
  • 如何使用镜像在阿里云服务器部署windows环境
  • 如何在阿里云服务器部署Redis第一篇
  • 如何在阿里云服务器部署程序并用域名直接访问
  • 怎么在阿里云服务器部署多个tomcat
  • 如何在阿里云服务器部署程序并用域名直接访
  • 如何在阿里云服务器部署Django
  • 阿里云ecs服务器中安装部署node.js的步骤
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全dockerhyper-vvmwarevirtualboxxenserverkvmqemuopenvzxencloudstackopenstack云计算技术云其它首页服务器云和虚拟化dockerdocker安装阿里云服务器和在虚拟机安装遇到的坑(问题小结)阿里云部署docker私有镜像仓库的实现步骤docker部署crownblog项目到阿里云的方法步骤docker镜像的制作,上传,拉取和部署操作(利用阿里云)阿里云esc服务器docker部署单节点mysql的讲解centos7 安装docker 解决启动不了的问题详解centos7 docker1.12安装私有仓库docker-修改容器挂载目录的3种方法小结详解docker pull 下来的镜像都存到了哪里docker容器配置nginx实例分享docker 数据卷及数据容器详细介绍及示例docker?mysql5.7如何设置不区分大小写idea集成docker实现远程部署的步骤centos7 安装jenkins详细介绍ubuntu16.04docker的cs模式详细介绍docker.service启动失败:unit not fodocker获取镜像报错docker: error respdocker 给运行中的容器设置端口映射的方法浅谈docker-compose网络设置之networksdocker 清理命令集锦docker容器访问宿主机网络的方法ubuntu vps安装docker报错:cannot coubuntu14.04+docker的安装及使用docker容器如何优雅的终止详解dockerfile中cmd和entrypoint命令详解docker搭建私有仓库之harbor的步骤详解使用dockerfile创建带apache服务的centos docke利用docker制作nginx+php镜像的步骤详解docker工作模式及原理详解docker数据卷容器创建及使用方法解析docker下搭建一个java tomcat运行环境的方法docker常用命令总结(推荐)创建支持ssh服务的docker镜像的方法docker部署zabbix_agent的方法步骤docker使用阿里云镜像仓库的方法
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved