Docker应用系列(三)| 构建Consul集群
本示例基于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集群的更多相关文章
- LVS系列三、LVS集群-IP-TUN模式
一.LVS-IP TUN集群概述 DR方式是通过MAC,规模是一个交换网络.而TUN方式,是通过给数据包加上新的IP头部来实现,这个可以跨整个广域网.TUN模式可以解决DR模式下不能跨网段的问题,甚至 ...
- Docker安装Consul集群
Docker 安装Consul集群 使用windows 环境,Docker desktop community 构建consul集群. 1.docker 容器网络 docker安装后,默认会创建三种网 ...
- 使用docker快速部署一个consul集群
作为一个开发者,有时候需要一个集群环境,之前的做法要么就是使用多个虚拟机,要么就是采用不同的端口来模拟,但是虚拟机比较占内存,而且启动慢,采用不同的端口来模拟,管理起来比较麻烦一些,程序隔离性差一些. ...
- vagrant+docker搭建consul集群开发环境
HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...
- 基于Docker的Consul集群实现服务发现
服务发现 其实简单说,服务发现就是解耦服务与IP地址之间的硬绑定关系,以典型的集群为例,对于集群来说,是有多个节点的,这些节点对应多个IP(或者同一个IP的不同端口号),集群中不同节点责任是不一样的. ...
- 使用Docker构建redis集群--最靠谱的版本
1集群结构说明 集群中有三个主节点,三个从节点,一共六个结点.因此要构建六个redis的docker容器.在宿主机中将这六个独立的redis结点关联成一个redis集群.需要用到官方提供的ruby脚本 ...
- Docker 容器部署 Consul 集群
Docker 容器部署 Consul 集群 一.docker安装与启动1.1安装docker[root@localhost /]# yum -y install docker-io 1.2更改配置文件 ...
- 实战中的asp.net core结合Consul集群&Docker实现服务治理
0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 一.前言 在写这篇文章之前,我看了很多关于consul的服务治理,但发现基本上都是直接在powershell或者以命令工具的方式在 ...
- .net core结合Consul集群&Docker实现服务治理
实战中的asp.net core结合Consul集群&Docker实现服务治理 https://www.cnblogs.com/guolianyu/p/9614050.html 0.目录 整体 ...
随机推荐
- background(css复合写法)
1. 背景-background========================================================== 单个属性的写法 .sample1 { /*背景颜色 ...
- org.hibernate.HibernateException: getFlushMode is not valid without active transaction
Spring & Hibernate 整合异常记录: org.hibernate.HibernateException: getFlushMode is not valid without a ...
- HDU 6061 推导 NTT
复函数,递归代入,可以得到最终的式子为$f(x-\sum_{i=1}^{m}{a_i})$,且$f(x) = \sum_{i = 0}^{n}{c_ix^i}$,求最终各个x项的系数. 设$S=\su ...
- 写一个简易浏览器、ASP.NET核心知识(3)
前言 先在文章前面说好了,省得大家发现我根本没有这样的头发,duang的一下一堆人骂我. 这篇文章的标题有点大,其实挺low的,我需要在开头解释一下.我这里只想写一个小的控制台,旨在模拟浏览器的htt ...
- 2017ACM暑期多校联合训练 - Team 6 1001 HDU 6096 String (字符串处理 字典树)
题目链接 Problem Description Bob has a dictionary with N words in it. Now there is a list of words in wh ...
- HDU 2593 Pirates’ Code (STL容器)
题目链接 Problem Description Davy Jones has captured another ship and is smiling contently under the sun ...
- NYOJ 221 Tree (二叉树)
题目链接 描述 Little Valentine liked playing with binary trees very much. Her favorite game was constructi ...
- Lithium中关键特性更新
Lithium中关键特性更新 1. Lithium特性更新概述 Lithium相对于Helium更新特性共27项,其中原有特性提升或增强13项,新增特性14项,如下表所示 特性类型 相对于Helium ...
- Django之cfrs跨站请求伪造和xfs攻击
跨站请求伪造 一.简介 django为用户实现防止跨站请求伪造的功能,通过中间件 django.middleware.csrf.CsrfViewMiddleware 来完成.而对于django中设置防 ...
- django框架<三>
一.ORM操作 1.django orm创建数据库的方法 (1)指定连接pymysql(python3.x),先配置__init__.py import pymysql pymysql.instal ...