一、Consul 理论知识
1.1、Consul 简介
Consul 是一个支持多数据中心分布式高可用的 服务发现 和 配置共享 的服务软件,由 HashiCorp 公司用 Go 语言开发,基于 Mozilla Public License 2.0 的协议进行开源。
主要特性:
- Consul 支持健康检查,并允许 HTTP 、GRPC 和 DNS 协议调用 API 存储键值对。
- 一致性协议采用 Raft 算法,用来保证服务的高可用。 使用 GOSSIP 协议管理成员和广播消息, 并且支持 ACL 访问控制。
consul的实例叫agent,agent有两种运行模式:server和client 。
官方建议每个Consul Cluster数据中心至少有3个或以上的运行在Server Mode的Agent,Client节点不限。
1.2、Consul 使用场合
- Docker 容器的注册与配置共享
- Coreos 实例的注册与配置共享
- SaaS 应用的配置共享、服务发现和健康检查。
- vitess 集群
- 与 confd 服务集成,动态生成 nginx 和 haproxy 配置文件
1.3、Consul 优势
- 使用 Raft 算法来保证一致性,比复杂的 Paxos 算法更直接。相比较而言,zookeeper 采用的是 Paxos,而 etcd
使用的则是 Raft。 - 支持 多数据中心,内外网的服务采用不同的端口进行监听。
多数据中心集群可以避免单数据中心的单点故障,而其部署则需要考虑网络延迟,分片等情况等. zookeeper 和 etcd
均不提供多数据中心功能的支持。 - 支持 健康检查。 etcd 不提供此功能。
- 支持 HTTP、DNS 和 GPRS 协议接口。 zookeeper 的集成较为复杂,etcd 只支持 http 协议。
- 官方提供 WEB管理界面,etcd 无此功能。
1.4、consul 端口
端口 | 说明 |
---|---|
TCP/8300 | 8300 |
TCP/UDP/8301 | 8301端口用于单个数据中心所有节点之间的互相通信,即对LAN池信息的同步。它使得整个数据中心能够自动发现服务器地址,分布式检测节点故障,事件广播(如领导选举时间)。 |
TCP/UDP/8302 | 8302端口用于单个或多个数据中心之间的服务器节点的信息同步,即对WAN池信息的同步。它针对互联网的高延迟进行了优化,能够实现跨数据中心请求。 |
8500 | 8500端口基于HTTP协议,用于API接口或web UI访问 |
8600 | 8600端口作为DNS服务器,它使得我们可以通过节点名查询节点信息 |
二:基于Docker的Consul服务搭建
2.1、环境准备
主机 | 主机IP | 安装工具 |
---|---|---|
consul服务器 | 192.168.158.10 | Docker、Consul、Consul-template模板、nginx代理服务 |
容器服务器 | 192.168.158.20 | Docker、registrator、nginx容器 |
2.2、部署Consul服务
//先创建一个目录
mkdir /root/consul
cd /root/consul
[root@server1 consul]# ls
consul-template_0.19.3_linux_amd64.zip
consul_0.9.2_linux_amd64.zip nginx-1.12.2.tar.gz
unzip consul_0.9.2_linux_amd64.zip
//使 consul 命令可以在任何目录下识别
mv consul /usr/bin
[root@server1 consul]# consul agent \
-server \
-bootstrap \
-ui \
-data-dir=/var/lib/consul-data \
-bind=192.168.158.10 \
-client=0.0.0.0 \
-node=consul-server01 &> /var/log/consul.log &
[1] 19458
[root@server1 consul]# netstat -natp | grep 8500
tcp6 0 0 :::8500 :::* LISTEN 19458/consul
#consul服务已经启动
#查看群集信息
[root@server1 consul]# consul members
Node Address Status Type Build Protocol DC
consul-server01 192.168.158.10:8301 alive server 0.9.2 2 dc1
[root@server1 consul]# consul info | grep leader
leader = true
leader_addr = 192.168.158.10:8300
2.3:通过 httpd api 可以获取集群信息:
[root@localhost consul]# curl 127.0.0.1:8500/v1/status/peers ##查看群集server成员
[root@localhost consul]# curl 127.0.0.1:8500/v1/status/leaders ##群集中 Raf leader
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/services ##注册的所有服务
[root@localhost consul]# curl 127.0.0.1:8500/v1/catalog/nodes ##群集节点详细信息
[root