为什么需要注册中心?是用Eeka还是Nacos?
作者:卡卷网发布时间:2025-01-11 16:38浏览数量:80次评论数量:0次
上一篇文章:如何设计一个注册中心?以Zookeeper为例
还是先讲讲各个中间件的区别,zookeeper已经讲过了,这里开始讲中间件的工作原理
<>1.Eeka工作原理</>
Eeka的文档:NetflixEeka
不过只有对1.0版本的文档,2.0之后的没有了。
对Eeka的解释:一种基于REST(表述性状态转移)的服务,主要用于AWS云中定位服务,以实现中间层的负载均衡和故障转移。称为Eeka。
Eeka解决的需求是:在AWS中,经常上线/下线,因此AWS需要动态地注册/注销负载均衡器上的,而Eeka就是这样作为中间层负载均衡器出现的。
1.1高可用架构
Eeka在多个机房部署的架构图如下,这也是它高可用的优势
解释说明:
1.2客户端-服务端间的通信
(1)注册Register
Eeka客户端将运行实例的信息注册到Eeka,注册在第一次心跳时发生(30秒后)
(2)续约机制Renew
客户端每隔30秒发送一次心跳来续租,通知Eeka实例,当前客户端仍然处于存活状态。如果在90秒内没有收到续租,它将把实例移出注册表;
(3)获取注册表FetchRegistry
<>(4)下线Cancel</>
Eeka在程序关闭时向Eeka发送取消请求。发送请求后,该客户端实例信息将从Eeka的实例注册表中删除。下线请求不会自动完成,需手动调用:
1.3自我保护机制
默认情况下,Eeka服务端在90s没有收到某个服务实例的心跳,就会注销该实例,将实例下线。如果出现大量实例心跳检测失败,Eeka就会认为是注册中心出现问题了,启动自我保护机制,<>不再剔除这些失败实例</>。触发条件阈值为:
1.4小结
2.Nacos工作原理
Nacos文档:Nacos架构2.3版本,注册中心设计原理文档:Nacos注册中心
上面的图较复杂,这里贴下人的关于注册中心这部分的架构图
整体流程也就是服务发现那套流程:
Nacos采用了<>Pull和Push同时运作</>的方式来保证本地服务实例列表的动态感知。服务消费者通过定时任务的方式每10sPull一次数据,Nacos在服务提供者出现变化时,基于UDP协议PUSH更新
2.1数据模型
Zookeeper使用的是抽象的树形K-V组织结构,没有专门的数据模型。Eeka或者Consul都是做到了实例级别的数据扩展。Nacos使用的是<>服务-集群-实例</>的三层数据模型。
从上图的分级数据模型可以看到:
2.2数据一致性协议选择(CPorAP)
Nacos因为要支持多种服务类型的注册,并能够具有机房容灾、集群扩展等必不可少的能力,是支持AP和CP两种一致性协议的,默认是AP模式
根据client注册时的属性,AP,CP同时混合存在,只是对不同的client节点效果不同。
Distro协议则是参考了内部Config和开源Eeka,在不借助第三方存储的情况下,实现基本大同小异。Distro重点是做了一些逻辑的优化和性能的调优。
3.注册中心较
对项目 | Nacos | Eeka | Consul | Zookeeper |
---|---|---|---|---|
一致性协议 | 支持AP和CP模式 | AP模式 | CP模式 | CP模式 |
健康检查 | TCP//MYSQL/eat | eat | TCP//gRPC/Cmd | KeepAlive |
负载均衡策略 | 权重/metadata/Selector | Rion | Faio | - |
幂等保护 | 有 | 有 | 无 | 无 |
自动注入实例 | 支持 | 支持 | 不支持 | 支持 |
访问协议 | /DNS | /DNS | TCP | |
监视支持 | 支持 | 支持 | 支持 | 支持 |
多数据中心 | 支持 | 支持 | 支持 | 不支持 |
跨注册中心同步 | 支持 | 支持 | 不支持 | 不支持 |
SpringCloud集成 | 支持 | 不支持 | 支持 | 不支持 |
Duo集成 | 支持 | 不支持 | 不支持 | 不支持 |
k8s集成 | 支持 | 不支持 | 不支持 | 不支持 |
3.1选型场景
Nacos
适用场景包括:
Eeka
Consul
没写关于consul的工作原理,简单列下适用场景:
Zookeeper
免责声明:本文由卡卷网编辑并发布,但不代表本站的观点和立场,只提供分享给大家。
相关推荐

你 发表评论:
欢迎