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的客戶端去服務端更新配置。

相關文章
相關標籤/搜索