springcloud(二):注册中心Eureka

ITvv · · 32 次点击 · · 开始浏览    
Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现。也是springcloud体系中最重要最核心的组件之一。愿意了解源码的朋友直接求求交流分享技术:二一四七七七五六三三 服务中心 服务中心又称注册中心,管理各种服务功能包括服务的注册、发现、熔断、负载、降级等,比如dubbo admin后台的各种功能。 有了服务中心调用关系会有什么变化,画几个简图来帮忙理解 项目A调用项目B 正常调用项目A请求项目B ![a-b.jpg](https://static.kotlintc.com/181127/8220b41ee7e3f6f8dd8e84442b620824.jpg) 有了服务中心之后,任何一个服务都不能直接去掉用,都需要通过服务中心来调用 ![af-b.jpg](https://static.kotlintc.com/181127/e5d16e85eb684ff077dfef356d7315ca.jpg) 项目A调用项目B,项目B在调用项目C ![a-ffb-c.jpg](https://static.kotlintc.com/181127/c68bbf0c8143476f18327767d1ef1bb1.jpg) 这时候调用的步骤就会为两步:第一步,项目A首先从服务中心请求项目B服务器,然后项目B在从服务中心请求项目C服务。 ![a-gf6-c-d.jpg](https://static.kotlintc.com/181127/f234478a720c8f852cec4ed37ba9e372.jpg) 上面的项目只是两三个相互之间的简单调用,但是如果项目超过20个30个呢,在15年底的时候我司分布式的项目就达到了二十几个,画一张图来描述几十个项目之间的相互调用关系全是线条,任何其中的一个项目改动,就会牵连好几个项目跟着重启,巨麻烦而且容易出错。通过服务中心来获取服务你不需要关注你调用的项目IP地址,由几台服务器组成,每次直接去服务中心获取可以使用的服务去调用既可。 由于各种服务都注册到了服务中心,就有了去做很多高级功能条件。比如几台服务提供相同服务来做均衡负载;监控服务器调用成功率来做熔断,移除服务列表中的故障点;监控服务调用时间来对不同的服务器设置不同的权重等等。 Eureka 按照官方介绍:Eureka 是一个基于 REST 的服务,主要在 AWS 云中使用, 定位服务来进行中间层服务器的负载均衡和故障转移。 Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server,并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。Spring Cloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。 Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。 用一张图来认识一下: ![认识一下.png](https://static.kotlintc.com/180831/daab1f6fd9e18cf87627a87f2af0dd9a.png)   上图简要描述了Eureka的基本架构,由3个角色组成: 1、Eureka Server  提供服务注册和发现 2、Service Provider  服务提供方  将自身服务注册到Eureka,从而使服务消费方能够找到 3、Service Consumer  服务消费方  从Eureka获取注册服务列表,从而能够消费服务 技术架构图如下: ![h5.jpg](https://static.kotlintc.com/181127/dbb59f7c446f5d0863e27ba38c487b88.jpg) [资料和源码来源 ](http://minglisoft.cn/honghu/technology.html)
32 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet