官方文档:https://www.consul.io/docs
Raft动画演示:http://thesecretlivesofdata.com/raft/
注册中心对比
Consul特点
服务发现、健康检查、Key/Value存储、安全服务通信(TLS证书)、多数据中心
架构
角色
- 数据中心
- 数据中心内,Client和Server通过LAN Gosssip 进行通信,同步集群节点信息,其保障了拓扑变动以及控制信号的及时传递
- 数据中心之间通过WAN Gosssip通信
- Client
- 每个服务部署一个Client
- Server
- 通过Raft算法选举,实现数据一致
- 当RPC请求到达非leader时,请求会被转发到leader上。
- 注册信息到达leader时,通过Raft向follower同步,超过半数follower同步成功时才认为注册成功。
- 建议部署3-5台
原理
服务注册
Producer启动时,向Consul Client注册,Client通过RPC将注册信息转发到Server,服务信息保存在Server各个节点中,通过Raft实现一致性。
Client定期向Producer发送健康检查。检查通过才会注册。
服务调用
Consumer向Consul Client请求Producer,Client将请求转发到Server,Server返回Producer的IP、Port的临时表,Consumer从中任选一个发起请求(负载均衡)