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.目录 整体 ...
随机推荐
- zoj 2314 Reactor Cooling (无源汇上下界可行流)
Reactor Coolinghttp://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1314 Time Limit: 5 Seconds ...
- 【BZOJ】2331: [SCOI2011]地板 插头DP
[题意]给定n*m的地板,有一些障碍格,要求用L型的方块不重不漏填满的方案数.L型方块是从一个方格向任意两个相邻方向延伸的方块,不能不延伸.n*m<=100. [算法]插头DP [题解]状态0表 ...
- ASP.Net Cache(缓存)—ASP.NET细枝末节(2)
概述 1.意义 把数据放到Cache中,在指定的时间内,可以直接从Cache中获取,避免对数据库等的压力. 2.做法 设置: HttpRuntime.Cache.Insert(CacheKey, ob ...
- React Native DEMO for Android
Demo1: 主要知识:navigator,fecth 地址:https://github.com/hongguangKim/ReactNativeDEMO1 Demo2: 主要知识:navigato ...
- python并发编程之gevent协程(四)
协程的含义就不再提,在py2和py3的早期版本中,python协程的主流实现方法是使用gevent模块.由于协程对于操作系统是无感知的,所以其切换需要程序员自己去完成. 系列文章 python并发编程 ...
- linux下生成core dump文件方法及设置【转】
转自:http://blog.csdn.net/mrjy1475726263/article/details/44116289 源自:http://andyniu.iteye.com/blog/196 ...
- java程序out of memory【转】
相信大家都有感触,线上服务内存OOM的问题,是最难定位的问题,不过归根结底,最常见的原因: 本身资源不够 申请的太多 资源耗尽 58到家架构部,运维部,58速运技术部联合进行了一次线上服务内存OOM问 ...
- 42.Trapping Rain Water---dp,stack,两指针
题目链接:https://leetcode.com/problems/trapping-rain-water/description/ 题目大意:与84题做比较,在直方图中计算其蓄水能力.例子如下: ...
- hosts,命令行前面的显示
1,/etc/hosts,主机名ip配置文件. # Do not remove the following line, or various programs # that require netwo ...
- Java web项目中新建maven项目出现的问题
1.首先新建maven项目,新建Maven时出现了版本问题,报错 第一个错误:jdk版本与project facets不匹配(大概是这样,忘记截图了),那么解决办法是: 在项目右击--->Pro ...