日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

java B2B2C springmvc mybatis电子商城系统(四)Ribbon

發布時間:2023/11/29 windows 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java B2B2C springmvc mybatis电子商城系统(四)Ribbon 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

一: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自帶負載均衡策略比較

策略名策略聲明策略描述實現說明
BestAvailableRulepublic class BestAvailableRule extends ClientConfigEnabledRoundRobinRule選擇一個最小的并發請求的server逐個考察Server,如果Server被tripped了,則忽略,在選擇其中ActiveRequestsCount最小的server
AvailabilityFilteringRulepublic class AvailabilityFilteringRule extends PredicateBasedRule過濾掉那些因為一直連接失敗的被標記為circuit tripped的后端server,并過濾掉那些高并發的的后端server(active connections 超過配置的閾值)使用一個AvailabilityPredicate來包含過濾server的邏輯,其實就就是檢查status里記錄的各個server的運行狀態
WeightedResponseTimeRulepublic class WeightedResponseTimeRule extends RoundRobinRule根據相應時間分配一個weight,相應時間越長,weight越小,被選中的可能性越低。一 個后臺線程定期的從status里面讀取評價響應時間,為每個server計算一個weight。Weight的計算也比較簡單responsetime 減去每個server自己平均的responsetime是server的權重。當剛開始運行,沒有形成statas時,使用roubine策略選擇 server。
RetryRulepublic class RetryRule extends AbstractLoadBalancerRule對選定的負載均衡策略機上重試機制。在一個配置時間段內當選擇server不成功,則一直嘗試使用subRule的方式選擇一個可用的server
RoundRobinRulepublic class RoundRobinRule extends AbstractLoadBalancerRuleroundRobin方式輪詢選擇server輪詢index,選擇index對應位置的server
RandomRulepublic class RandomRule extends AbstractLoadBalancerRule隨機選擇一個server在index上隨機,選擇index對應位置的server
ZoneAvoidanceRulepublic class ZoneAvoidanceRule extends PredicateBasedRule復合判斷server所在區域的性能和server的可用性選擇server使 用ZoneAvoidancePredicate和AvailabilityPredicate來判斷是否選擇某個server,前一個判斷判定一個 zone的運行性能是否可用,剔除不可用的zone(的所有server),AvailabilityPredicate用于過濾掉連接數過多的 Server。
?

? ?五:Ribbon單獨使用

? ? 創建一個maven工程 名稱 ribbon_client

? ? ?pom內容

<dependencies><dependency><groupId>com.netflix.ribbon</groupId><artifactId>ribbon-core</artifactId><version>2.2.0</version></dependency><dependency><groupId>com.netflix.ribbon</groupId><artifactId>ribbon-httpclient</artifactId><version>2.2.0</version></dependency> </dependencies>

整體架構如下:

Spring Cloud大型企業分布式微服務云構建的B2B2C電子商務平臺源碼請加企鵝求求: 一零叁八七七四六貳六

轉載于:https://my.oschina.net/u/4045192/blog/2999097

總結

以上是生活随笔為你收集整理的java B2B2C springmvc mybatis电子商城系统(四)Ribbon的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。