eureka原理

一.eureka注册中心原理

1.服务注册:

eureka客户端会通过发送rest请求的方式向eureka服务端注册自身元数据:ip地址,端口,运行状况等信息,服务端会把注册信息存储在一个双层map中

2.服务续约:

eureka客户端每30秒发送一次心跳来续约,告知客户端正常,如果eureka服务端90秒没收到心跳,则将其从注册表删除

3.获取注册表信息:

客户端通过rest请求从服务端获取注册表信息,缓存在本地,服务调用的时候,会从注册表查找其它服务,每30秒更新一次

4.服务调用

客户端获取到服务清单后,就可以从中查找其它服务地址进行远程调用,会通过ribbon自动进行负载均衡

5.eureka高可用:服务同步

配置eureka集群,服务之间会相互注册,客户端的注册信息和续约信息被复制到集群中的所有节点,只要有一个节点活着都可以发挥注册中心的作用

6.服务剔除

eureka服务启动的时候创建一个定时任务,每60秒从当前服务清单中剔除续约超时的(90秒)

7.自我保护机制

当网络一段时间内发生了异常,所有服务都没能够续约,eureka server会把所有服务剔除,显然不太合理,所以就有了自我保护机制

服务端如果15分钟内收到的心跳请求率,如果低于85%,可能网络故障,注册表则不再删除,但是提供正常的服务注册和查询,当恢复正常时,则取消保护机制

7.eureka客户端注册实例为什么这么慢:

(1)默认设置了延时40秒

(2)eureka服务端维护每30秒更新响应缓存

(3)客户端每30秒更新缓存

(4)ribbon从本地获取服务列表时,本身也维护一个缓存,30秒刷新一次

二.eureka service服务端源代码图

 

 

三.eureka client客户端源代码

 

四.多级缓存优点

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值