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客户端源代码

四.多级缓存优点

发布了42 篇原创文章 · 获赞 25 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/qq812858143/article/details/104219045