SpringCloud分布式的五大重点

SpringCloud分布式的五大重点的基本介绍java

服务器的注册与发现—Netflix Eurekanginx

客户端负载均衡—Netflix Ribbongit

断路器—Netflix Hystrix算法

服务网关—Netflix Zuui服务器

分布式配置—Spring Cloud Config负载均衡

Eureka:框架

一个RESTful服务,用来定位运行在AWS地区(Region)中的中间层服务。 运维

它由两个组件组成:Eureka服务器和Eureka客户端。 异步

1. Eureka服务器用做服务注册服务器。 分布式

2. Eureka客户端是一个java客户端,用来简化与服务器的交互、做为轮询负载均衡器,并提供服务的故障切换支持。 

Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。

Ribbon

主要提供客户侧的软件负载均衡算法。 

Ribbon客户端组件提供一系列完善的配置选项,好比链接超时、重试、重试算法等。 

Ribbon内置可插拔、可定制的负载均衡组件。

一些经常使用的负载均衡策略: 

1. 简单轮询负载均衡 

2. 加权响应时间负载均衡 

3. 区域感知轮询负载均衡 

4. 随机负载均衡 

Ribbon中还包括一下功能: 

1. 易于与服务发现组件(好比Netflix的Eureka)集成 

2. 使用Archaius完成运行时配置 

3. 使用JMX暴露运维指标,使用Servo发布 

4. 多种可插拔的序列化选择 

5. 异步和批处理操做(即将推出) 

6. 自动SLA框架(即将推出) 

7. 系统管理/指标控制台(即将推出)

Hystrix

断路器能够防止一个应用程序屡次试图执行一个操做,即极可能失败,容许它继续而不等待故障恢复或者浪费 CPU 周期,而它肯定该故障是持久的.

断路器模式也使应用程序可以检测故障是否已经解决。若是问题彷佛已经获得纠正​​,应用程序能够尝试调用操做。

断路器增长了稳定性和灵活性,以一个系统,提供稳定性,而系统从故障中恢复,并尽可能减小此故障的对性能的影响。它能够帮助快速地拒绝对一个操做,即极可能失败,而不是等待操做超时(或者不返回)的请求,以保持系统的响应时间。若是断路器提升每次改变状态的时间的事件,该信息能够被用来监测由断路器保护系统的部件的健康情况,或以提醒管理员当断路器跳闸,以在打开状态。

Zuui

相似nginx,反向代理的功能,不过netflix本身增长了一些配合其余组件的特性。

Spring Cloud Config

SpringCloudConfig就是咱们一般意义上的分布式配置中心,把应用本来放在本地文件的配置抽取出来放在中心服务器,从而可以提供更好的管理、 发布能力。

SpringCloudConfig分为服务端和客户端,服务端负责将git(svn)中存储的配置文件发布成REST接口,客户端能够从服务端REST接口获取配置。但客户端并不能主动感知到配置的变化,从而主动去获取新的配置, 它须要每一个客户端经过POST方法触发各自的/refresh,SpringCloudBus就经过一个轻量级消息代理链接分布式系统的节点。

能够用于广播状态更改(如配置更改)或其余管理指令。

SpringCloudBus提供了经过POST方法访问的endpoint/bus/refresh,这个接口一般由git的钩子功能调用,用以通知各个SpringCloudConfig的客户端去服务端更新配置。

相关文章
相关标签/搜索