Eureka架构中三个核心角色:
- 服务注册中心(Eureka的服务端应用,提供服务注册和发现功能)
- 服务提供者(提供服务的应用,可以是SpringBoot应用,也可以是其它任意技术实现)
- 服务消费者(消费应用从注册中心获取服务列表,从而得知每个服务方的信息,知道去哪里调用服务方)
Eureka好比医院门诊,负责管理、记录服务提供者的信息。服务调用者不需要自己寻找服务,而是把需求告诉Eureka,然后Eureka把符合你的需求的服务告诉你。
Eureka说白了就是一个注册服务中心。
同时,服务提供方与Eureka之间通过
“心跳”
机制进行监控,当某个服务提供方出现问题,Eureka自然会把它从服务列表中剔除。
这就实现了服务的自动注册、发现、状态监控。
原理图
- Eureka:就是服务注册中心(可以是一个集群),对外暴露自己的地址
- 提供者:启动后向Eureka注册自己信息(地址,提供什么服务)
- 消费者:向Eureka订阅服务,Eureka会将对应服务的所有提供者地址列表发送给消费者,并且定期更新
- 心跳(续约):提供者定期通过http方式向Eureka刷新自己的状态