Eureka

JAVA学习网 2019-02-28 16:50:03

分布式服务必然要面临的问题:

    服务管理
  - 如何自动注册和发现
  - 如何实现状态监管
  - 如何实现动态路由
  - 服务如何实现负载均衡
  - 服务如何解决容灾问题
  - 服务如何实现统一配置

  现在日益复杂的互联网环境,一个项目肯定会拆分出十几,甚至数十个微服务。此时如果还人为管理地址,不仅开发困难,将来测试、发布上线都会非常麻烦,这与DevOps的思想是背道而驰的。

Eureka做什么

  Eureka 负责管理、记录服务提供者的信息。服务调用者无需自己寻找服务,而是把自己的需求告诉Eureka,然后Eureka会把符合你需求的服务告诉你。

同时,服务提供方与Eureka之间通过`“心跳”`机制进行监控,当某个服务提供方出现问题,Eureka自然会把它从服务列表中剔除。

这就实现了服务的自动注册、发现、状态监控。

 

1.原理图

 

* Eureka:就是服务注册中心(可以是一个集群),对外暴露自己的地址

* 提供者:启动后向Eureka注册自己的信息(地址、提供什么服务)

* 消费者:向Eureka订阅服务,Eureka会将相对应服务的所有提供者地址列表发送给消费者、并且定期更新

* 心跳(续约):提供者定期通过http方式向Eureka刷新自己的状态

       消费者定期拉取,注意拉取和推送的概念

未完待续....

 

阅读(2850) 评论(0)