spring cloud构建互联网分布式微服务云平台-Ribbon
一:Ribbon是什么?
Ribbon是Netflix發布的開源項目,主要功能是提供客戶端的軟件負載均衡算法,將Netflix的中間層服務連接在一起。Ribbon客戶端組件提供一系列完善的配置項如連接超時,重試等。簡單的說,就是在配置文件中列出Load Balancer(簡稱LB)后面所有的機器,Ribbon會自動的幫助你基于某種規則(如簡單輪詢,隨即連接等)去連接這些機器。我們也很容易使用Ribbon實現自定義的負載均衡算法。愿意了解源碼的朋友直接求求交流分享技術 一七九一七四三三八零
二:LB方案分類
目前主流的LB方案可分成兩類:一種是集中式LB, 即在服務的消費方和提供方之間使用獨立的LB設施(可以是硬件,如F5, 也可以是軟件,如nginx), 由該設施負責把訪問請求通過某種策略轉發至服務的提供方;另一種是進程內LB,將LB邏輯集成到消費方,消費方從服務注冊中心獲知有哪些地址可用,然后自己再從這些地址中選擇出一個合適的服務器。Ribbon就屬于后者,它只是一個類庫,集成于消費方進程,消費方通過它來獲取到服務提供方的地址。
三:Ribbon的主要組件與工作流程
Ribbon的核心組件(均為接口類型)有以下幾個:
ServerList
用于獲取地址列表。它既可以是靜態的(提供一組固定的地址),也可以是動態的(從注冊中心中定期查詢地址列表)。
ServerListFilter
僅當使用動態ServerList時使用,用于在原始的服務列表中使用一定策略過慮掉一部分地址。
IRule
選擇一個最終的服務地址作為LB結果。選擇策略有輪詢、根據響應時間加權、斷路器(當Hystrix可用時)等。
Ribbon在工作時首選會通過ServerList來獲取所有可用的服務列表,然后通過ServerListFilter過慮掉一部分地址,最后在剩下的地址中通過IRule選擇出一臺服務器作為最終結果。
四:Ribbon提供的主要負載均衡策略介紹
1:簡單輪詢負載均衡(RoundRobin)
以輪詢的方式依次將請求調度不同的服務器,即每次調度執行i = (i + 1) mod n,并選出第i臺服務器。
2:隨機負載均衡 (Random)
隨機選擇狀態為UP的Server
3:加權響應時間負載均衡 (WeightedResponseTime)
根據相應時間分配一個weight,相應時間越長,weight越小,被選中的可能性越低。
4:區域感知輪詢負載均衡(ZoneAvoidanceRule)
復合判斷server所在區域的性能和server的可用性選擇server。
Ribbon自帶負載均衡策略比較
轉載于:https://juejin.im/post/5c6e0668e51d4520f01772f8
總結
以上是生活随笔為你收集整理的spring cloud构建互联网分布式微服务云平台-Ribbon的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 阿里云ARMS重磅推出小程序监控,助力小
- 下一篇: 诺基亚新Logo遭网友神吐槽:过于抽象