docker进阶-利用dcoker Swarm搭建简单集群
什么是Swarm
在介绍Swarm之前我们要说一下什么Docker三剑客?
- Docker-Machine:负责在多种平台上快速安装 Docker 环境。
- Docker-Compose:Docker官网编排工具。负责快速的部署分布式应用
- Docker-Swarm: Docker 容器集群服务,是 Docker 官方对容器云生态进行支持的核心方案。
Swarm翻译中文的意思是蜂群的意思。大家都知道蜂群是很很多多蜜蜂在一起。里面有蜂王和工蜂,各司其职。那么在我们技术界把许许多多的Docker组织在一起,这样就是Docker集群。Swarm就是管理这些Docker的工具。同蜂群一样。也有蜂王(Master节点)工蜂(Node节点)各司其职。蜂王能调度和指挥所有的工蜂来完成各种任务。实现整个蜂群的正常运转。
为什么要用Swarm
因为在生产环境中使用单个Docker节点是远远不够的,搭建Docker集群势在必行。 这样能保证我们的服务可以做到不怠机。长时间稳定的运转下去。虽然Docker集群管理工具很多,有比较有名的Kubernetes和Mesos。但是我们为什么要选择Swarm呢?。首先对于一个刚刚入门和接触Docker的人来说。最好的学习资料是官方文档。Swarm是原生的,同时也是最简单,最易学,最节省资源的Docker集群管理工具。所以我相信Swarm不会让我失望的。
关于Machine
由于我们等会要使用Machine来创建节点。所以介绍Machine的基本使用。
Machine安装
#由于MacOs在安装docker的时候。已经默认安装Machine.这里根据官网给出的Linux安装命令
sudo curl -L https://github.com/docker/machine/releases/download/v0.13.0/docker-machine-`uname -s`-`uname -m` > /usr/local/bin/docker-machine
#添加权限
sudo chmod +x /usr/local/bin/docker-machine
#查看当前Machine版本
docker-machine -v
#安装MacOs虚拟机xhyve驱动。也可以跳过
brew install docker-machine-driver-xhyve
使用Machine 创建虚拟机
使用Machine创建4个虚拟机
#create命令后面可以添加自定义参数.可以通过docker-machine create --driver virtualbox --help查看
#创建Master节点.这里dm因为我使用自定义命令。等同于docker-machine
dm create Master
#可以通过ls命令查看当前虚拟机.然后我们分别建立3个node节点,node1,node2,node3
dm create Node1
dm create Node2
dm create Node3
#创建然后通过ls查看
dm ls
######################
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
Master - virtualbox Running tcp://192.168.99.100:2376 v18.03.0-ce
Node1 - virtualbox Running tcp://192.168.99.102:2376 v18.03.0-ce
Node2 - virtualbox Running tcp://192.168.99.103:2376 v18.03.0-ce
Node3 - virtualbox Running tcp://192.168.99.103:2376 v18.03.0-ce
到此4台虚拟机已经创建完毕。下面开始使用Swarm搭建一个集群。
Swarm实践
创建集群
首先我们需要登录到Master这台虚拟机。创建初始化一个集群。
#登录到Master
dm ssh Master
#初始化集群。注意这里由于是虚拟机。有多个ip。所有必须制定ip.否则会报错.
docker swarm init --advertise-addr 192.168.99.100
#这里会提示创建manager成功。如果要加入worker。只需要在别的主机里面输入它已经生成的号的命令输入就可以了。
docker swarm join --token SWMTKN-1-03e4mo13jpizh15kroub1qsxdxk6zj8qgu2y3acwi1v14zaqpe-e6hhlamgqa9m7w4601biqqtg9 192.168.99.100:2377
#登入Node1
dm ssh Node1
#输入上面命令。Node2和Node3操作一样
docker swarm join --token SWMTKN-1-03e4mo13jpizh15kroub1qsxdxk6zj8qgu2y3acwi1v14zaqpe-e6hhlamgqa9m7w4601biqqtg9 192.168.99.100:2377
#登录Master,查看状态
dm ssh Master
#查看集群
docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
0vol8fdjksmabvmgx0x60ncyd * Master Ready Active Leader 18.03.0-ce
jnuun47ezvi0bl1iz1ccxmgto Node1 Ready Active 18.03.0-ce
ye6ghynu19tvdkf51kof13w6y Node2 Ready Active 18.03.0-ce
x84fqdefi4461gf087qcb9nmt Node3 Ready Active 18.03.0-ce
这里会看到4台虚拟机。其中Master台是Leader (就是我们的蜂王),剩下的3台就是我们的worker(工蜂)到这里我们一个简单的小集群就搭建完毕了。
运行服务
我们已经搭建好了集群。但是要怎么样通过Master管理我们的worker节点呢?
首先我们需要登录到Master这台虚拟机。然后通过这个台虚拟机来控制3个worker节点
#登录Master
dm ssh Master
#运行服务。
docker service create --replicas 4 -p 80:80 --name nginx nginx
#查看集群运行的服务
service ps nginx

这个时候4个虚拟机已经全部安装了nginx这个服务。我们打开任意一个节点的ip打开就可以看到熟悉的"Welcome to nginx!"的页面了。到此整个教程结束。
docker进阶-利用dcoker Swarm搭建简单集群的更多相关文章
- 初学Hadoop:利用VMWare+CentOS7搭建Hadoop集群
一.前言 开始学习数据处理相关的知识了,第一步是搭建一个Hadoop集群.搭建一个分布式集群需要多台电脑,在此我选择采用VMWare+CentOS7搭建一个三台虚拟机组成的Hadoop集群. 注:1 ...
- Apache httpd + tomcat 简单集群
集群其实很简单,我们就来说一下httpd+tomcat集群都要注意哪些部分: 首先使用的东西有 apache-tomcat-8.0.32 下载地址: http://tomcat.apache ...
- asp.net core 认证及简单集群
众所周知,在Asp.net WebAPI中,认证是通过AuthenticationFilter过滤器实现的,我们通常的做法是自定义AuthenticationFilter,实现认证逻辑,认证通过,继续 ...
- nginx做负载均衡和tomcat简单集群
Nginx做负载均衡和TOMCAT简单集群 1.下载安装nginx及其依赖包 ...
- Nginx+Tomcat简单集群
1.软件准备下载Nginx和Tomcat解压到一个目录2.修改Tomcat的端口Tomcat1:修改Server.xmlTomcat2:修改Server.xml3.测试Tomcat是否正常运行分别访问 ...
- net core 认证及简单集群
net core 认证及简单集群 在Asp.net WebAPI中,认证是通过AuthenticationFilter过滤器实现的,我们通常的做法是自定义AuthenticationFilter,实现 ...
- Mysql---搭建简单集群,实现主从复制,读写分离
参考博客:https://blog.csdn.net/xlgen157387/article/details/51331244 A. 准备:多台服务器,且都可以互相随意访问root用户,都可以随意进行 ...
- [原创]Docker学习记录: Shipyard+Swarm+Consul+Service Discover 搭建教程
网上乱七八糟的资料实在是太多了, 乱, 特别乱, 而看书呢, 我读了2本书, 一本叫做<>, 另一本叫做<< Docker进阶与实战>> 在 服务发现这块讲的又不清 ...
- docker~swarm搭建docker高可用集群
回到目录 Swarm概念 Swarm是Docker公司推出的用来管理docker集群,它将一群Docker宿主机变成一个单一的,虚拟的主机.Swarm使用标准的Docker API接口作为其前端访问入 ...
随机推荐
- 机器学习中应用到的各种距离介绍(附上Matlab代码)
转载于博客:各种距离 在做分类时常常需要估算不同样本之间的相似性度量(SimilarityMeasurement),这时通常采用的方法就是计算样本间的"距离"(Distance). ...
- DirectShow中写push模式的source filter流程 + 源代码(内附详细注释)
虽然网上已有很多关于DirectShow写source filter的资料,不过很多刚开始学的朋友总说讲的不是很清楚(可能其中作者省略了许多他认为简 单的过程),读者总希望看到象第一步怎么做,第二步怎 ...
- 小白学爬虫-批量部署Splash负载集群
整体目录如下: study@study:~/文档/ansible-examples$ tree Splash_Load_balancing_cluster Splash_Load_balancing_ ...
- box-sizing -- 盒模型
项目开发中,在浏览同事的代码,发现他经常用一个属性--box-sizing,很好奇是什么,于是乎,上网查阅资料学了起来. 首先我们先复习一下盒模型的组成:一个div通常由 content(内容)+ma ...
- C#读取Excel表格中数据并返回datatable
在软件开发的过程中,经常用到从excel表格中读取数据作为数据源,以下整理了一个有效的读取excel表格的方法. DataTable GetDataTable(string tableName,str ...
- ProgressBar、ProgessDialog用法解析
一.ProgressBar 1. 常用类型 1.1 不确定式圆形进度条 style="@android:style/Widget.Holo.Light.ProgressBar" s ...
- webpacke踩坑-新手
1.题叶-webpack入门指南 2.webpack入门系列 3.w3ctech的webpack入门及实践 4.Express结合Webpack的全栈自动刷新 5.webpack 单页面应用实战 6. ...
- 【CJOJ2484】【Luogu2805】最小函数值(函数最小值)
题面 Description 有n个函数,分别为F1,F2,...,Fn.定义 Fi(x)=Aix2+Bix+Ci(x∈N∗)Fi(x)=Aix2+Bix+Ci(x∈N∗) .给定这些Ai.Bi和Ci ...
- 【CJOJ2316】【模板】可持久化线段树
题面 Description 这是一道非常直白的可持久化线段树的练习题,目的并不是虐人,而是指导你入门可持久化数据结构. 线段树有个非常经典的应用是处理RMQ问题,即区间最大/最小值询问问题.现在我们 ...
- luoguP2711 小行星
题目描述 星云中有n颗行星,每颗行星的位置是(x,y,z).每次可以消除一个面(即x,y或z坐标相等)的行星,但是由于时间有限,求消除这些行星的最少次数. 输入输出格式 输入格式: 第1行为小行星个数 ...