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

    服务管理
  – 如何自动注册和发现

  – 如何实现状态监管


  – 如何实现动态路由

  – 服务如何实现负载均衡
  – 服务如何解决容灾问题
  – 服务如何实现统一配置

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

Eureka做什么

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

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


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

 

1.原理图

 

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

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

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

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

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

未完待续….

 

版权声明:本文为dnwsj原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/dnwsj/p/10446291.html