本示例基于Centos 7,在阿里云的三台机器上部署consul集群,假设目前使用的账号为release,拥有sudo权限。

由于Docker官方镜像下载较慢,可以开启阿里云的Docker镜像下载加速器,可参考此文进行配置。

假设三台主机的ip分别为:

  • 主机一:192.168.0.1
  • 主机二:192.168.0.2
  • 主机三:192.168.0.3

三台主机的安装步骤相似,以主机一为例:

1. 安装docker服务:

 sudo yum install -y docker

2. 启动docker服务:

sudo service docker start

3. 查找consul镜像:

sudo docker search consul

4. 下载官方consul镜像:

sudo  docker pull docker.io/consul

5. 下载完后可检查镜像:

sudo docker images 

6. 三台主机上建立数据目录和配置目录,目录为空即可:

mkdir -p /data/consul_data/data
mkdir -p /data/consul_data/conf

7. 三台主机依次启动容器:

主机一的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect= -data-dir /consul/data -config-dir /consul/config

主机二的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect= -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1

主机三的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.3 -bootstrap-expect= -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1

命令说明:

  • --net=host:采用主机网络配置,若采用默认的bridge模式,则会存在容器跨主机间通信失败的问题
  • -v /data/consul_data/data:/consul/data:主机的数据目录挂载到容器的/consul/data下,因为该容器默认的数据写入位置即是/consul/data
  • -v /data/consul_data/conf:/consul/config:主机的配置目录挂载到容器的/consul/conf下,因为该容器默认的数据写入位置即是/consul/conf
  • consul agent -server:consul的server启动模式
  • consul agent -bind=192.168.0.3:consul绑定到主机的ip上
  • consul agent  -bootstrap-expect=3:server要想启动,需要至少3个server
  • consul agent -data-dir /consul/data:consul的数据目录
  • consul agent -config-dir /consul/config:consul的配置目录
  • consul agent -join 192.168.0.1:对于主机二、三来说,需要加入到这个集群里

都启动完成后,可以通过如下命令观察consul日志,了解启动情况:

sudo docker logs 容器id/容器名称

日志情况示例如下:

[release@sh-lbs02 data]$ sudo docker logs consul
[sudo] password for release:
bootstrap_expect > : expecting servers
==> Starting Consul agent...
==> Joining cluster...
Join completed. Synced with initial agents
==> Consul agent running!
Version: 'v1.2.3'
Node ID: '56e5b37e-b636-3cfa-6a9b-2ce47e0dfbd1'
Node name: 'sh-lbs02'
Datacenter: 'dc1' (Segment: '<all>')
Server: true (Bootstrap: false)
Client Addr: [127.0.0.1] (HTTP: , HTTPS: -, DNS: )
Cluster Addr: 192.168.0.1 (LAN: , WAN: )
Encrypt: Gossip: false, TLS-Outgoing: false, TLS-Incoming: false

8. 检查集群状态:

sudo docker exec -it 容器id /bin/sh

通过该命令进入容器,查看集群信息:

[release@sh-lbs02 data]$ sudo docker exec -it 8a /bin/sh
/ # consul members
Node Address Status Type Build Protocol DC Segment
lbs02 192.168.0.1: alive server 1.2. dc1 <all>
web01 192.168.0.2: alive server 1.2. dc1 <all>
web02 192.168.0.3: alive server 1.2. dc1 <all>
/ #

至此,集群已启动完成,consul的端口打开较多,可以在主机上观察其端口情况:

[release@sh-web02 ~]$ sudo netstat -tlnp|grep consul
[sudo] password for release:
tcp 192.168.0.1: 0.0.0.0:* LISTEN /consul
tcp 192.168.0.1: 0.0.0.0:* LISTEN /consul
tcp 192.168.0.1: 0.0.0.0:* LISTEN /consul
tcp 127.0.0.1: 0.0.0.0:* LISTEN /consul
tcp 127.0.0.1: 0.0.0.0:* LISTEN /consul

9. 如何启动consul客户端?假设consul客户端与服务端在同一个主机上:

首先,建立客户端的配置目录和数据目录:

mkdir -p /data/consul_data_cli/data
mkdir -p /data/consul_data_cli/conf

其次,在配置目录下分配客户端使用的端口,避免与服务端的端口冲突:

cd /data/consul_data_cli/conf
touch basic.json
vi basic.json
#内容如下:
{
"ports": {
"http":,
"dns":,
"rpc":,
"serf_lan":,
"serf_wan":,
"server":
}
}

最后,启动客户端:

sudo docker run  --net=host --name consul-cli -v /data/consul_data_cli/data:/consul/data -v /data/consul_data_cli/conf:/consul/config -d docker.io/consul consul agent -bind=192.168.0.2 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1:

Docker应用系列(三)| 构建Consul集群的更多相关文章

  1. LVS系列三、LVS集群-IP-TUN模式

    一.LVS-IP TUN集群概述 DR方式是通过MAC,规模是一个交换网络.而TUN方式,是通过给数据包加上新的IP头部来实现,这个可以跨整个广域网.TUN模式可以解决DR模式下不能跨网段的问题,甚至 ...

  2. Docker安装Consul集群

    Docker 安装Consul集群 使用windows 环境,Docker desktop community 构建consul集群. 1.docker 容器网络 docker安装后,默认会创建三种网 ...

  3. 使用docker快速部署一个consul集群

    作为一个开发者,有时候需要一个集群环境,之前的做法要么就是使用多个虚拟机,要么就是采用不同的端口来模拟,但是虚拟机比较占内存,而且启动慢,采用不同的端口来模拟,管理起来比较麻烦一些,程序隔离性差一些. ...

  4. vagrant+docker搭建consul集群开发环境

    HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...

  5. 基于Docker的Consul集群实现服务发现

    服务发现 其实简单说,服务发现就是解耦服务与IP地址之间的硬绑定关系,以典型的集群为例,对于集群来说,是有多个节点的,这些节点对应多个IP(或者同一个IP的不同端口号),集群中不同节点责任是不一样的. ...

  6. 使用Docker构建redis集群--最靠谱的版本

    1集群结构说明 集群中有三个主节点,三个从节点,一共六个结点.因此要构建六个redis的docker容器.在宿主机中将这六个独立的redis结点关联成一个redis集群.需要用到官方提供的ruby脚本 ...

  7. Docker 容器部署 Consul 集群

    Docker 容器部署 Consul 集群 一.docker安装与启动1.1安装docker[root@localhost /]# yum -y install docker-io 1.2更改配置文件 ...

  8. 实战中的asp.net core结合Consul集群&Docker实现服务治理

    0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 一.前言 在写这篇文章之前,我看了很多关于consul的服务治理,但发现基本上都是直接在powershell或者以命令工具的方式在 ...

  9. .net core结合Consul集群&Docker实现服务治理

    实战中的asp.net core结合Consul集群&Docker实现服务治理 https://www.cnblogs.com/guolianyu/p/9614050.html 0.目录 整体 ...

随机推荐

  1. uva 10288 Coupons (分数模板)

    https://vjudge.net/problem/UVA-10288 大街上到处在卖彩票,一元钱一张.购买撕开它上面的锡箔,你会看到一个漂亮的图案. 图案有n种,如果你收集到所有n(n≤33)种彩 ...

  2. Do the Untwist(模拟)

    ZOJ Problem Set - 1006 Do the Untwist Time Limit: 2 Seconds      Memory Limit: 65536 KB Cryptography ...

  3. 基于 Express+Gulp+BrowserSync 搭建一套高性能的前端开发环境

    基于 Express+Gulp+BrowserSync 搭建一套高性能的前端开发环境 Express 是比较经典的,也是最常用的 Nodejs Web框架. 一.Express 快速构建一个web应用 ...

  4. 【IDEA】 Can't Update No tracked branch configured for branch master or the branch doesn't exist. To make your branch track a remote branch call, for example, git branch --set-upstream-to origin/master

    IDEA点击GIT更新按钮时,报错如下: Can't UpdateNo tracked branch configured for branch master or the branch doesn' ...

  5. jq消除网页滚动条

    网页有些时候需要能滚动的效果,但是不想要滚动条,我就遇到了这样的需求.自己用jq写了一个垂直滚动条. 纯css也可以实现 .box::-webkit-scrollbar{display:none} 但 ...

  6. script标签中type为<script type="text/x-template">是个啥

    写过一点前端的都会碰到需要使用JS字符串拼接HTML元素然后append到页面DOM树上的情况,一般的写法都是使用+号以字符串的形式拼接,如果是短点的还好,如果很长很长的话就会拼接到令人崩溃了. 比如 ...

  7. 6 - Python内置结构 - 字典

    目录 1 字典介绍 2 字典的基本操作 2.1 字典的定义 2.2 字典元素的访问 2.3 字典的增删改 3 字典遍历 3.1 遍历字典的key 3.2 遍历字典的value 3.3 变量字典的键值对 ...

  8. Mac Sublime Vim模式 方向键无法长按

    终端输入 sublime2: defaults write com.sublimetext.2 ApplePressAndHoldEnabled -bool false sublime3: defau ...

  9. 26_Python的内置函数

    The Python interpreter has a number of functions and types built into it that are always available.P ...

  10. /proc/sys 子目录的作用

    该子目录的作用是报告各种不同的内核参数,并让您能交互地更改其中的某些.与 /proc 中所有其他文件不同,该目录中的某些文件可以写入,不过这仅针对 root. 其中的目录以及文件的详细列表将占据过多的 ...