欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring?Cloud?Ribbon?中的?7?種負載均衡策略的實現(xiàn)方法

 更新時間:2022年03月14日 10:38:59   作者:Java中文社群  
Ribbon?內(nèi)置了?7?種負載均衡策略:輪詢策略、權(quán)重策略、隨機策略、最小連接數(shù)策略、重試策略、可用性敏感策略、區(qū)域性敏感策略,并且用戶可以通過繼承?RoundRibbonRule?來實現(xiàn)自定義負載均衡策略,對Spring?Cloud?Ribbon負載均衡策略相關(guān)知識感興趣的朋友一起看看吧

負載均衡通器常有兩種實現(xiàn)手段,一種是服務(wù)端負載均衡器,另一種是客戶端負載均衡器,而我們今天的主角 Ribbon 就屬于后者——客戶端負載均衡器。

服務(wù)端負載均衡器的問題是,它提供了更強的流量控制權(quán),但無法滿足不同的消費者希望使用不同負載均衡策略的需求,而使用不同負載均衡策略的場景確實是存在的,所以客戶端負載均衡就提供了這種靈活性。 然而客戶端負載均衡也有其缺點,如果配置不當(dāng),可能會導(dǎo)致服務(wù)提供者出現(xiàn)熱點,或者壓根就拿不到任何服務(wù)的情況,所以我們本文就來了解一下這 7 種內(nèi)置負載均衡策略的具體規(guī)則。

Ribbon 介紹

Ribbon 是 Spring Cloud 技術(shù)棧中非常重要的基礎(chǔ)框架,它為 Spring Cloud 提供了負載均衡的能力,比如 Fegin 和 OpenFegin 都是基于 Ribbon 實現(xiàn)的,就連 Nacos 中的負載均衡也使用了 Ribbon 框架。

Ribbon 框架的強大之處在于,它不僅內(nèi)置了 7 種負載均衡策略,同時還支持用戶自定義負載均衡策略,所以其開放性和便利性也是它得以流行的主要原因。

服務(wù)端負載均衡器和客戶端負載均衡器的區(qū)別如下圖所示:


客戶端負載均衡器的實現(xiàn)原理是通過注冊中心,如 Nacos,將可用的服務(wù)列表拉取到本地(客戶端),再通過客戶端負載均衡器(設(shè)置的負載均衡策略)獲取到某個服務(wù)器的具體 ip 和端口,然后再通過 Http 框架請求服務(wù)并得到結(jié)果,其執(zhí)行流程如下圖所示:

負載均衡設(shè)置

以 Nacos 中的 Ribbon 負載均衡設(shè)置為例,在配置文件 application.yml 中設(shè)置如下配置即可:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #設(shè)置負載均衡策略

因為 Nacos 中已經(jīng)內(nèi)置了 Ribbon,所以在實際項目開發(fā)中無需再添加 Ribbon 依賴了,這一點我們在 Nacos 的依賴樹中就可以看到,如下圖所示:

Ribbon 默認(rèn)的負載均衡策略是輪詢模式,我們配置 3 個服務(wù)提供者的執(zhí)行結(jié)果如下圖所示:

然后,我們再將 Ribbon 負載均衡策略設(shè)置為隨機模式,配置內(nèi)容如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #設(shè)置隨機負載均衡

重啟客戶端,執(zhí)行結(jié)果如下圖所示:

7種負載均衡策略

1.輪詢策略

輪詢策略:RoundRobinRule,按照一定的順序依次調(diào)用服務(wù)實例。比如一共有 3 個服務(wù),第一次調(diào)用服務(wù) 1,第二次調(diào)用服務(wù) 2,第三次調(diào)用服務(wù)3,依次類推。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #設(shè)置負載均衡

2.權(quán)重策略

權(quán)重策略:WeightedResponseTimeRule,根據(jù)每個服務(wù)提供者的響應(yīng)時間分配一個權(quán)重,響應(yīng)時間越長,權(quán)重越小,被選中的可能性也就越低。
它的實現(xiàn)原理是,剛開始使用輪詢策略并開啟一個計時器,每一段時間收集一次所有服務(wù)提供者的平均響應(yīng)時間,然后再給每個服務(wù)提供者附上一個權(quán)重,權(quán)重越高被選中的概率也越大。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.WeightedResponseTimeRule

3.隨機策略

隨機策略:RandomRule,從服務(wù)提供者的列表中隨機選擇一個服務(wù)實例。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #設(shè)置負載均衡

4.最小連接數(shù)策略

最小連接數(shù)策略:BestAvailableRule,也叫最小并發(fā)數(shù)策略,它是遍歷服務(wù)提供者列表,選取連接數(shù)最小的?個服務(wù)實例。如果有相同的最小連接數(shù),那么會調(diào)用輪詢策略進行選取。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.BestAvailableRule #設(shè)置負載均衡

5.重試策略

重試策略:RetryRule,按照輪詢策略來獲取服務(wù),如果獲取的服務(wù)實例為 null 或已經(jīng)失效,則在指定的時間之內(nèi)不斷地進行重試來獲取服務(wù),如果超過指定時間依然沒獲取到服務(wù)實例則返回 null。
此策略的配置設(shè)置如下:

ribbon:
  ConnectTimeout: 2000 # 請求連接的超時時間
  ReadTimeout: 5000 # 請求處理的超時時間
springcloud-nacos-provider: # nacos 中的服務(wù) id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #設(shè)置負載均衡

6.可用性敏感策略

可用敏感性策略:AvailabilityFilteringRule,先過濾掉非健康的服務(wù)實例,然后再選擇連接數(shù)較小的服務(wù)實例。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.AvailabilityFilteringRule

7.區(qū)域敏感策略

區(qū)域敏感策略:ZoneAvoidanceRule,根據(jù)服務(wù)所在區(qū)域(zone)的性能和服務(wù)的可用性來選擇服務(wù)實例,在沒有區(qū)域的環(huán)境下,該策略和輪詢策略類似。
此策略的配置設(shè)置如下:

springcloud-nacos-provider: # nacos中的服務(wù)id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.ZoneAvoidanceRule

項目源碼

https://gitee.com/mydb/spring-cloud-alibaba-example

總結(jié)

Ribbon 為客戶端負載均衡器,相比于服務(wù)端負載均衡器的統(tǒng)一負載均衡策略來說,它提供了更多的靈活性。Ribbon 內(nèi)置了 7 種負載均衡策略:輪詢策略、權(quán)重策略、隨機策略、最小連接數(shù)策略、重試策略、可用性敏感策略、區(qū)域性敏感策略,并且用戶可以通過繼承 RoundRibbonRule 來實現(xiàn)自定義負載均衡策略。

到此這篇關(guān)于Spring Cloud Ribbon 中的 7 種負載均衡策略的文章就介紹到這了,更多相關(guān)Spring Cloud Ribbon負載均衡策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

  • java后端如何獲取完整url的代碼

    java后端如何獲取完整url的代碼

    這篇文章主要介紹了java后端如何獲取完整url的代碼問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • maven安裝、使用、配置本地倉庫、idea配置maven以及解決plugins報錯問題

    maven安裝、使用、配置本地倉庫、idea配置maven以及解決plugins報錯問題

    本地倉庫是遠程倉庫的一個緩沖和子集,當(dāng)你構(gòu)建Maven項目時首先會從本地倉庫查找資源,如果沒有那么Maven會從遠程倉庫下載到你本地倉庫,這篇文章主要給大家介紹了關(guān)于maven安裝、使用、配置本地倉庫、idea配置maven以及解決plugins報錯問題的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • 二叉搜索樹實例練習(xí)

    二叉搜索樹實例練習(xí)

    一棵二叉查找樹是按二叉樹結(jié)構(gòu)來組織的。這樣的樹可以用鏈表結(jié)構(gòu)表示,其中每一個結(jié)點都是一個對象
    2012-11-11
  • Java獲得一個數(shù)組的指定長度排列組合算法示例

    Java獲得一個數(shù)組的指定長度排列組合算法示例

    這篇文章主要介紹了Java獲得一個數(shù)組的指定長度排列組合算法,結(jié)合實例形式分析了java排列組合相關(guān)數(shù)組遍歷、運算操作技巧,需要的朋友可以參考下
    2019-06-06
  • Java?ClassLoader虛擬類實現(xiàn)代碼熱替換的示例代碼

    Java?ClassLoader虛擬類實現(xiàn)代碼熱替換的示例代碼

    本文主要介紹了Java?ClassLoader虛擬類實現(xiàn)代碼熱替換的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Java annotation元注解原理實例解析

    Java annotation元注解原理實例解析

    這篇文章主要介紹了Java annotation元注解原理實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • Java?Web中ServletContext對象詳解與應(yīng)用

    Java?Web中ServletContext對象詳解與應(yīng)用

    ServletContext是一個容器,可以用來存放變量,供一個web項目中多個Servlet共享,下面這篇文章主要給大家介紹了關(guān)于Java?Web中ServletContext對象詳解與應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • springboot多個service互相調(diào)用的事務(wù)處理方式

    springboot多個service互相調(diào)用的事務(wù)處理方式

    這篇文章主要介紹了springboot多個service互相調(diào)用的事務(wù)處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 攜程Apollo(阿波羅)安裝部署以及java整合實現(xiàn)

    攜程Apollo(阿波羅)安裝部署以及java整合實現(xiàn)

    這篇文章主要介紹了攜程Apollo(阿波羅)安裝部署以及java整合實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 最新評論