本文介绍了在 Windows 10 上基于 Docker 搭建 Consul 多数据中心集群的步骤,包括 Consul 镜像的拉取和容器的创建,每个数据中心对应服务端节点和客户节点的创建,节点之间相互加入组成集群,数据中心之间进行关联。多数据中心集群建立之后,通过 Consul 提供的 WEB UI 可以对集群中每个节点健康状况和服务的监控。最后列出了几个常用的命令,用于查看数据中心和节点的状态,以及对节点进行一些操作。

1 准备工作

1.1 环境说明

操作系统:Windows 10

Docker:V18.06.1-ce, build e68fc7a

Consul:V1.2.2

1.2 准备环境

1.2.1 安装 Docker

在 Windows 10 中下载 Docker 并进行安装,安装过程请参考其他教程。

注意:

1、请确认你的 Windows 10 支持虚拟化(CPU 支持 VMX 指令集);

2、后面所述的集群搭建过程中,有些步骤不适用于其他版本的 Windows 系统,即使你安装的是 Docker Toolbox;

1.2.2 拉取 Consul 镜像

Docker 安装成功后,我们使用 Windows PowerShell 来拉取 Consul 镜像,你也可以使用其他任何命令行工具。

docker pull consul

2 搭建数据中心(dc1)

2.1 节点1

docker run -d -p 8500:8500 --name node1 consul agent -server -bootstrap-expect 3 -data-dir=/tmp/consul -client="0.0.0.0" -ui

启用 WEB UI,并将端口映射到 8500,方便通过 WEB 的方式查看群集状态,默认数据中心为 dc1

为了后续创建的节点能够加入到该节点,我们先获取节点 node1 的 IP 地址并绑定到 JOIN_IP 变量:

JOIN_IP="$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1)"

上述命令在 Windows 10 的 PowerShell 下运行时会报以下错误:

PS C:\Users\Administrator> JOIN_IP="$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1)"
JOIN_IP=$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1) : 无法将“JOIN_IP=$(docker inspect -f '{{.NetworkSe
ttings.IPAddress}}' node1)”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路
径正确,然后再试一次。
所在位置 行:1 字符: 1
+ JOIN_IP="$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1)"
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : ObjectNotFound: (JOIN_IP=$(docke...dress}}' node1):String) [], CommandNotFoundException
+ FullyQualifiedErrorId : CommandNotFoundException

我们直接使用以下命令查看 node1 的 IP 地址:

docker inspect -f '{{.NetworkSettings.IPAddress}}' node1

PS C:\Users\Administrator> docker inspect -f '{{.NetworkSettings.IPAddress}}' node1
172.17.0.2

2.2 节点2

docker run -d --name node2 consul agent -server -join 172.17.0.2

如果 JOIN_IP 绑定成功,则可以使用以下命令创建:

docker run -d --name node2 consul agent -server -join $JOIN_IP

2.3 节点3

docker run -d --name node3 consul agent -server -join 172.17.0.2

2.4 节点4

docker run -d --name node4 consul agent -server -join 172.17.0.2

接下来查看一下数据中心 dc1 的节点

docker exec node1 consul members

PS C:\Users\Administrator> docker exec node1 consul members
Node Address Status Type Build Protocol DC Segment
227adc80c8e4 172.17.0.3:8301 alive server 1.2.2 2 dc1 <all>
d22c4d8ccc50 172.17.0.2:8301 alive server 1.2.2 2 dc1 <all>
e78cba259433 172.17.0.4:8301 alive server 1.2.2 2 dc1 <all>
f05abd19bb5f 172.17.0.5:8301 alive server 1.2.2 2 dc1 <all>

3 搭建数据中心(dc2)

3.1 节点5

docker run -d --name node5 consul agent -server -bootstrap-expect 2 -datacenter=dc2

使用以下命令查看 node5 的 IP 地址:

docker inspect -f '{{.NetworkSettings.IPAddress}}' node5

3.2 节点6

docker run -d --name node6 consul agent -server -datacenter=dc2 -join 172.17.0.6

注意一定要加上 -datacenter=dc2,不然不能加入数据中心2

3.3 节点7

docker run -d --name node7 consul agent -server -datacenter=dc2 -join 172.17.0.6

3.4 节点8

这里我们添加一个客户端节点,注意没有 -server 参数。一个数据中心 Consul 一般建议 3~5 个 Server 节点,而客户端节点并没有限制,你可以添加数万个节点都没有问题。

docker run -d --name node8 consul agent -datacenter=dc2 -join 172.17.0.6

接下来我们查看一下数据中心 dc2 的节点:

docker exec node5 consul members

PS C:\Users\Administrator> docker exec node5 consul members
Node Address Status Type Build Protocol DC Segment
19ee3676f49b 172.17.0.6:8301 alive server 1.2.2 2 dc2 <all>
7859fe7002fe 172.17.0.7:8301 alive server 1.2.2 2 dc2 <all>
fce88e9c0ffc 172.17.0.8:8301 alive server 1.2.2 2 dc2 <all>
318fa22df7c9 172.17.0.9:8301 alive client 1.2.2 2 dc2 <default>

4 关联数据中心

这里我们选择数据中心2的节点 node5 关联到数据中心1中 IP 地址为 172.17.0.2 的 node1 节点,你也可以选择其他节点进行关联,只要这两个节点分别位于两个数据中心即可。

docker exec node5 consul join -wan 172.17.0.2

看到以下信息说明关联数据中心成功

PS C:\Users\Administrator> docker exec node5 consul join -wan 172.17.0.2
Successfully joined cluster by contacting 1 nodes.

5 在 WEB 界面查看

在浏览器中访问 http://127.0.0.1:8500 地址,即可看到所有的服务和节点,还可以通过切换数据中心查看其下的服务和节点,点击每个节点可以进一步查看具体节点的健康状况、运行的服务以及响应时间等信息。

6 常用命令

6.1 列出数据中心

docker exec node5 consul catalog datacenters

PS C:\Users\Administrator> docker exec node5 consul catalog datacenters
dc2
dc1

6.2 列出节点

docker exec node5 consul catalog nodes

PS C:\Users\Administrator> docker exec node5 consul catalog nodes
Node ID Address DC
19ee3676f49b 8f6b15db 172.17.0.6 dc2
318fa22df7c9 3d1d2c28 172.17.0.9 dc2
7859fe7002fe d49c88c2 172.17.0.7 dc2
fce88e9c0ffc fca52e5e 172.17.0.8 dc2

可以将 node5 换成其他节点名称,该命令会列出指定节点所在数据中心的所有节点。

6.3 移除节点

docker exec node8 consul operator raft remove-peer -id=172.17.0.9:8301

(该命令没有运行成功,先记录一下。)

6.4 查询群集中所有的 LAN 和 WAN 的 Server 节点

docker exec node5 consul members -wan

PS C:\Users\Administrator> docker exec node5 consul members -wan
Node Address Status Type Build Protocol DC Segment
19ee3676f49b.dc2 172.17.0.6:8302 alive server 1.2.2 2 dc2 <all>
227adc80c8e4.dc1 172.17.0.3:8302 alive server 1.2.2 2 dc1 <all>
7859fe7002fe.dc2 172.17.0.7:8302 alive server 1.2.2 2 dc2 <all>
d22c4d8ccc50.dc1 172.17.0.2:8302 alive server 1.2.2 2 dc1 <all>
e78cba259433.dc1 172.17.0.4:8302 alive server 1.2.2 2 dc1 <all>
f05abd19bb5f.dc1 172.17.0.5:8302 alive server 1.2.2 2 dc1 <all>
fce88e9c0ffc.dc2 172.17.0.8:8302 alive server 1.2.2 2 dc2 <all>

其中 `node5`` 可以换成关联数据中心中的其他任意节点名称

6.5 查看集群状态

docker exec node5 consul operator raft list-peers

PS C:\Users\Administrator> docker exec node5 consul operator raft list-peers
Node ID Address State Voter RaftProtocol
19ee3676f49b 8f6b15db-8b15-0853-390a-d0f71f7bb61f 172.17.0.6:8300 leader true 3
7859fe7002fe d49c88c2-744b-556f-f709-45c252158b7c 172.17.0.7:8300 follower true 3
fce88e9c0ffc fca52e5e-8d69-82c1-ae1e-dba9718d1e41 172.17.0.8:8300 follower true 3

可以添加 -stale 参数查看旧的集群状态

基于 Docker 搭建 Consul 多数据中心集群的更多相关文章

  1. 基于Docker的Consul服务发现集群搭建

    在去年的.NET Core微服务系列文章中,初步学习了一下Consul服务发现,总结了两篇文章.本次基于Docker部署的方式,以一个Demo示例来搭建一个Consul的示例集群,最后给出一个HA的架 ...

  2. 一台虚拟机,基于docker搭建大数据HDP集群

    前言 好多人问我,这种基于大数据平台的xxxx的毕业设计要怎么做.这个可以参考之前写得关于我大数据毕业设计的文章.这篇文章是将对之前的毕设进行优化. 个人觉得可以分为两个部分.第一个部分就是基础的平台 ...

  3. 庐山真面目之十二微服务架构基于Docker搭建Consul集群、Ocelot网关集群和IdentityServer版本实现

    庐山真面目之十二微服务架构基于Docker搭建Consul集群.Ocelot网关集群和IdentityServer版本实现 一.简介      在第七篇文章<庐山真面目之七微服务架构Consul ...

  4. ActiveMQ此例简单介绍基于docker的activemq安装与集群搭建

    ActiveMQ拓展连接 此例简单介绍基于Docker的activemq安装与集群搭建 一 :安装 1.获取activemq镜像 docker pull webcenter/activemq 2.启动 ...

  5. Docker搭建MySQL的PXC集群

    原文:Docker搭建MySQL的PXC集群 一.简介 PXC属于一套近乎完美的mysql高可用集群解决方案,相比那些比较传统的基于主从复制模式的集群架构MHA和MM+keepalived,galer ...

  6. 基于docker实现redis高可用集群

    基于docker实现redis高可用集群 yls 2019-9-20 简介 基于docker和docker-compose 使用redis集群和sentinel集群,达到redis高可用,为缓存做铺垫 ...

  7. centos7环境搭建Eureka-Server注册中心集群

    目的:测试和线上使用这套独立的Eureka-Server注册中心集群,目前3台虚拟机集群,后续可直接修改配置文件进行新增或减少集群机器. 系统环境: Centos7x64 java8+(JDK1.8+ ...

  8. 基于 ZooKeeper 搭建 Spark 高可用集群

    一.集群规划 二.前置条件 三.Spark集群搭建         3.1 下载解压         3.2 配置环境变量         3.3 集群配置         3.4 安装包分发 四.启 ...

  9. Spark学习之路(七)—— 基于ZooKeeper搭建Spark高可用集群

    一.集群规划 这里搭建一个3节点的Spark集群,其中三台主机上均部署Worker服务.同时为了保证高可用,除了在hadoop001上部署主Master服务外,还在hadoop002和hadoop00 ...

随机推荐

  1. 手写简易SpringMVC

    手写简易SpringMVC 手写系列框架代码基于普通Maven构建,因此在手写SpringMVC的过程中,需要手动的集成Tomcat容器 必备知识: Servlet相关理解和使用,Maven,Java ...

  2. 利用Serverless应用搭建Hexo博客

    本文将介绍如何使用火爆的Serverless应用,15分钟快速搭建Hexo博客.以腾讯云提供的Serverless应用–云开发为例: 步骤1:安装 CloudBase CLI 以及本地部署 Hexo ...

  3. WPF 有缩放时显示线条的问题

    公司项目已经开发好几年了,用的WPF开发的,期间遇到好多问题,都是些小细节.很久没有写博客了,以后有时间还是需要写写博客啊!作为分享也好.记录也好,利人利己嘛. 今天主要说一下显示线条的问题,因为我们 ...

  4. Java基础之java8新特性(1)Lambda

    一.接口的默认方法.static方法.default方法. 1.接口的默认方法 在Java8之前,Java中接口里面的默认方法都是public abstract 修饰的抽象方法,抽象方法并没有方法实体 ...

  5. MySQL(一)简介与入门

    一.数据库简介 这个博客详细介绍:http://www.cnblogs.com/progor/p/8729798.html 二.MySQL的安装 这个博客详细介绍:https://blog.csdn. ...

  6. 花了一个月的时间在一个oj网站只刷了这些题,从此入门了绝大多数算法

    如果你想入门算法,那么我这篇文章也许可以帮到你. oj网站有这么多,当然还有其他的.我当初是在hdu上面刷的,不要问我为什么,问就是当时我也是一个新手,懵懵懂懂就刷起来了.点这里可以进入这个网站htt ...

  7. Java SE基础知识

    Java SE面试题 目录 Java SE基础 基本语法 数据类型 关键字 面向对象 集合 集合类概述 Collection接口 List Set Map Java SE基础 基本语法 数据类型 Ja ...

  8. linux gdb 入门级教程(小白专用)

    送给包含我在内的所有小白: 对于养linux真姬的本小白来说,既然你选择养它,那你就要满足他. 如果你养了它是为了码代码,那我觉得gdb应该是它的基本需求了吧?! 然而gdb哪有那些IDE来的简单啊, ...

  9. Django开发之ORM批量操作

    版本 1 Python 3.8.2 2 Django 3.0.6 批量入库 场景: 前端页面通过 textarea 文本框提交一列多行数据到Django后台,后台通过ORM做入库操作 表名: Tabl ...

  10. 小甲鱼零基础汇编语言学习笔记第二章之寄存器(CPU工作原理,CPU内部通讯)

    这一章主要介绍了CPU中的重要器件——寄存器,整个系列通篇是以8086CPU作为探讨对象,其它更高级的CPU都是在此基础之上进行的升级.   1.一个典型的CPU是由运算器.控制器.寄存器等器件组成, ...