溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringCloud-Ribbon如何實(shí)現(xiàn)負(fù)載均衡

發(fā)布時(shí)間:2021-09-29 14:54:05 來(lái)源:億速云 閱讀:125 作者:柒染 欄目:編程語(yǔ)言

本篇文章給大家分享的是有關(guān)SpringCloud-Ribbon如何實(shí)現(xiàn)負(fù)載均衡,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

Ribbon 作為一款客戶端負(fù)載均衡框架,默認(rèn)的負(fù)載策略是輪詢,同時(shí)也提供了很多其他的策略,能夠讓用戶根據(jù)自身的業(yè)務(wù)需求進(jìn)行選擇。
整體策略代碼實(shí)現(xiàn)類如圖 1 所示。

SpringCloud-Ribbon如何實(shí)現(xiàn)負(fù)載均衡

圖中說(shuō)明如下:

1)BestAvailabl

選擇一個(gè)最小的并發(fā)請(qǐng)求的 Server,逐個(gè)考察 Server,如果 Server 被標(biāo)記為錯(cuò)誤,則跳過(guò),然后再選擇 ActiveRequestCount 中最小的 Server。

2)AvailabilityFilteringRule

過(guò)濾掉那些一直連接失敗的且被標(biāo)記為 circuit tripped 的后端 Server,并過(guò)濾掉那些高并發(fā)的后端 Server 或者使用一個(gè) AvailabilityPredicate 來(lái)包含過(guò)濾 Server 的邏輯。其實(shí)就是檢查 Status 里記錄的各個(gè) Server 的運(yùn)行狀態(tài)。

3)ZoneAvoidanceRule

使用 ZoneAvoidancePredicate 和 AvailabilityPredicate 來(lái)判斷是否選擇某個(gè) Server,前一個(gè)判斷判定一個(gè) Zone 的運(yùn)行性能是否可用,剔除不可用的 Zone(的所有 Server),AvailabilityPredicate 用于過(guò)濾掉連接數(shù)過(guò)多的 Server。

4)RandomRule

隨機(jī)選擇一個(gè) Server。

5)RoundRobinRule

輪詢選擇,輪詢 index,選擇 index 對(duì)應(yīng)位置的 Server。

6)RetryRule

對(duì)選定的負(fù)載均衡策略機(jī)上重試機(jī)制,也就是說(shuō)當(dāng)選定了某個(gè)策略進(jìn)行請(qǐng)求負(fù)載時(shí)在一個(gè)配置時(shí)間段內(nèi)若選擇 Server 不成功,則一直嘗試使用 subRule 的方式選擇一個(gè)可用的 Server。

7)ResponseTimeWeightedRule

作用同 WeightedResponseTimeRule,ResponseTime-Weighted Rule 后來(lái)改名為 WeightedResponseTimeRule。

8)WeightedResponseTimeRule

根據(jù)響應(yīng)時(shí)間分配一個(gè) Weight(權(quán)重),響應(yīng)時(shí)間越長(zhǎng),Weight 越小,被選中的可能性越低。

以上就是SpringCloud-Ribbon如何實(shí)現(xiàn)負(fù)載均衡,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI