文章目录
- 一、Consul 理论概述
- 1.1 简介
- 1.2 使用场景
- 1.3 优势
- 1.4 consul 端口
- 二、基于Docker的Consul服务搭建
- 2.1 部署环境
- 2.2 部署Consul服务
- 2.3 容器服务自动加入nginx集群
- 2.4 验证consul 的服务发现功能
一、Consul 理论概述
1.1 简介
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 使用场景
- Docker 容器的注册与配置共享
- Coreos 实例的注册与配置共享
- SaaS 应用的配置共享、服务发现和健康检查。
- vitess 集群
- 与 confd 服务集成,动态生成 nginx 和 haproxy 配置文件
1.3 优势
市面现在有很多类似的软件比如:zookeeper 、Etcd、doozerd、eureka,Consul 相比这些软件的优势:
- 使用 Raft 算法来保证一致性,比复杂的 Paxos 算法更直接。相比较而言,zookeeper 采用的是 Paxos,而 etcd 使用的则是 Raft。
- 支持 多数据中心,内外网的服务采用不同的端口进行监听。 多数据中心集群可以避免单数据中心的单点故障,而其部署则需要考虑网络延迟,分片等情况等. zookeeper 和 etcd 均不提供多数据中心功能的支持。
- 支持 健康检查。 etcd 不提供此功能。
- 支持 HTTP、DNS 和 GPRS 协议接口。 zookeeper 的集成较为复杂,etcd 只支持 http 协议。
- 官方提供 WEB管理界面,etcd 无此功能。
1.4 consul 端口
端口 | 说明 |
---|
TCP/8300 | 8300端口用于服务器节点,客户端通过该端口RPC协议调用服务端节点。 |
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 | 20.0.0.50 | Docker-ce、Consul、Consul-template模板、nginx服务 |
容器 | 20.0.0.60 | Docker-ce |
2.2 部署Consul服务
[root@consul ~]
[root@consul ~]
[root@consul ~]
[root@consul ~]
[root@consul consul]
总用量 13588
-rw-r--r--. 1 root root 10233177 12月 1 13:49 consul_0.9.2_linux_amd64.zip
-rw-r--r--. 1 root root 2694811 12月 1 16:21 consul-template_0.19.3_linux_amd64.zip
-rw-r--r--. 1 root root 980831 12月 1 16:25 nginx-1.12.0.tar.gz
[root@consul consul]
[root@consul consul]
[root@consul consul]
-server \
-bootstrap \
-ui \
-data-dir=/var/lib/consul-data \
-bind=20.0.0.50 \
-client=0.0.0.0 \
-node=consul-server01 &> /var/log/consul.log &
[root@consul consul]
tcp6 0 0 :::8500 :::* LISTEN 48140/consul
[root@consul consul]
Node Address Status Type Build Protocol DC
consul-server01 20.0.0.50:8301 alive server 0.9.2 2 dc1
[root@consul consul]
leader = true
leader_addr = 20.0.0.50:8300
- 使用浏览器访问
2.3 容器服务自动加入nginx集群
[root@node ~]
--name=registrator \
--net=host \
-v /var/run/docker.sock:/tmp/docker.sock \
--restart=always \
gliderlabs/registrator:latest \
-ip=20.0.0.60 \
consul://20.0.0.50:8500
[root@node ~]
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
287f08f49e16 gliderlabs/registrator:latest "/bin/registrator -i…" 15 seconds ago Up 14 seconds registrator
[root@node ~]
[root@node ~]
[root@node ~]
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
03bca01167d4 nginx "/docker-entrypoint.…" 3 seconds ago Up 2 seconds 0.0.0.0:84->80/tcp test-02
ecaf03f3eca5 nginx "/docker-entrypoint.…" 45 seconds ago Up 44 seconds 0.0.0.0:83->80/tcp test-01
287f08f49e16 gliderlabs/registrator:latest "/bin/registrator -i…" 6 minutes ago Up 6 minutes registrator
2.4 验证consul 的服务发现功能
- 或者通过命令查看consul服务器
- 删除一个nginx容器查看变化
[root@node ~]
03bca01167d4
[root@node ~]
03bca01167d4
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)