Consul原理介绍

官方文档:https://www.consul.io/docs

Raft动画演示:http://thesecretlivesofdata.com/raft/

注册中心对比

Consul特点

服务发现、健康检查、Key/Value存储、安全服务通信(TLS证书)、多数据中心

架构


角色

  • 数据中心
    1. 数据中心内,Client和Server通过LAN Gosssip 进行通信,同步集群节点信息,其保障了拓扑变动以及控制信号的及时传递
    2. 数据中心之间通过WAN Gosssip通信
  • Client
    1. 每个服务部署一个Client
  • Server
    1. 通过Raft算法选举,实现数据一致
    2. 当RPC请求到达非leader时,请求会被转发到leader上。
    3. 注册信息到达leader时,通过Raft向follower同步,超过半数follower同步成功时才认为注册成功。
    4. 建议部署3-5台

原理

服务注册

Producer启动时,向Consul Client注册,Client通过RPC将注册信息转发到Server,服务信息保存在Server各个节点中,通过Raft实现一致性。

Client定期向Producer发送健康检查。检查通过才会注册。

服务调用

Consumer向Consul Client请求Producer,Client将请求转发到Server,Server返回Producer的IP、Port的临时表,Consumer从中任选一个发起请求(负载均衡)

相关推荐
希望永不加班13 天前
SpringBoot 服务注册与发现:Nacos/Consul/Eureka
java·spring boot·eureka·consul·java-consul
成为你的宁宁16 天前
【基于 Consul 实现 Prometheus 服务发现部署与实战】
prometheus·consul
白露与泡影22 天前
轻量级微服务发布系统:Traefik + Nomad + Consul
微服务·架构·consul
日取其半万世不竭1 个月前
Consul:服务发现与健康检查,微服务架构的注册中心
架构·服务发现·consul
开开心心就好1 个月前
近200个工具的电脑故障修复合集
安全·智能手机·pdf·电脑·consul·memcache·1024程序员节
风口旁的猪2 个月前
一套可落地的 .NET 8 微服务/分布式工程实践
docker·consul·.net core·efcore·refit
要做一个小太阳2 个月前
Consul SD 常见标签
运维·数据库·consul
zs宝来了2 个月前
Consul 服务网格原理:Gossip 协议与 Raft 一致性
服务发现·consul·服务网格·gossip协议·raft一致性
@atweiwei2 个月前
深入解析gRPC服务发现机制
微服务·云原生·rpc·go·服务发现·consul
Java面试题总结2 个月前
测试文章 #95 — 平台发布验证(51CTO/OSCHINA/Juejin)
consul