Springcloud - Consul

本文详细介绍了Consul的基础概念,包括其服务发现、健康检查和key/value存储等功能,对比了与Eureka的区别,着重讲解了Consul的强一致性特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Consul基础概念

Consul是一个分布式高可用系统,作为一个整体在微服务架构中提供服务注册和服务配置的工具。Spring Cloud Consul 项目是针对Consul的服务治理实现。

特性:
1、服务发现
2、健康检查
3、key/value 存储
4、多数据中心

工作原理
在这里插入图片描述
1、当 Producer 启动的时候,会向 Consul 发送一个 post 请求,告诉 Consul 自己的 IP 和 Port
2、Consul 接收到 Producer 的注册后,每隔10s(默认)会向 Producer 发送一个健康检查的请求,检验Producer是否健康
3、当 Consumer 发送 GET 方式请求 /api/address 到 Producer 时,会先从 Consul 中拿到一个存储服务 IP 和 Port 的临时表,从表中拿到 Producer 的 IP 和 Port 后再发送 GET 方式请求 /api/address
4、该临时表每隔10s会更新,只包含有通过了健康检查的 Producer。

Consul和Eureka的区别

1、一致性 Consul强一致性(CP)

  • 服务注册相比Eureka会稍慢一些。因为Consul的raft协议要求必须过半数的节点都写入成功才认 为注册成功。
  • Leader挂掉时,重新选举期间整个consul不可用。保证了强一致性但牺牲了可用性。

2、Eureka保证高可用和最终一致性(AP)

  • 服务注册相对要快,因为不需要等注册信息replicate到其他节点,也不保证注册信息是否 replicate成功。
  • 当数据出现不一致时,虽然A, B上的注册信息不完全相同,但每个Eureka节点依然能够正常对外提 供服务,这会出现查询服务信息时如果请求A查不到,但请求B就能查到。如此保证了可用性但牺牲了一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值