国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略

這篇具有很好參考價(jià)值的文章主要介紹了【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

前言

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

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

一、Ribbon 介紹

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

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

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

【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略,# Spring Cloud,spring cloud,ribbon,負(fù)載均衡

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

二、負(fù)載均衡設(shè)置

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

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

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

【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略,# Spring Cloud,spring cloud,ribbon,負(fù)載均衡

Ribbon 默認(rèn)的負(fù)載均衡策略是輪詢模式,我們配置 3 個(gè)服務(wù)提供者的執(zhí)行結(jié)果如下圖所示:
【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略,# Spring Cloud,spring cloud,ribbon,負(fù)載均衡

然后,我們?cè)賹?Ribbon 負(fù)載均衡策略設(shè)置為隨機(jī)模式,配置內(nèi)容如下:

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

重啟客戶端,執(zhí)行結(jié)果如下圖所示:
【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略,# Spring Cloud,spring cloud,ribbon,負(fù)載均衡

三、7種負(fù)載均衡策略

3.1.輪詢策略

輪詢策略:RoundRobinRule,按照一定的順序依次調(diào)用服務(wù)實(shí)例。比如一共有 3 個(gè)服務(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è)置負(fù)載均衡

3.2.權(quán)重策略

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

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

3.3.隨機(jī)策略

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

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

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

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

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

3.5.重試策略

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

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

3.6.可用性敏感策略

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

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

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

區(qū)域敏感策略:ZoneAvoidanceRule,根據(jù)服務(wù)所在區(qū)域(zone)的性能和服務(wù)的可用性來選擇服務(wù)實(shí)例,在沒有區(qū)域的環(huán)境下,該策略和輪詢策略類似。
此策略的配置設(shè)置如下:文章來源地址http://www.zghlxwxcb.cn/news/detail-606606.html

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

到了這里,關(guān)于【Spring Cloud】Ribbon 中的幾種負(fù)載均衡策略的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 【Spring Cloud 四】Ribbon負(fù)載均衡

    【Spring Cloud 四】Ribbon負(fù)載均衡

    【Spring Cloud一】微服務(wù)基本知識(shí) 【Spring Cloud 三】Eureka服務(wù)注冊(cè)與服務(wù)發(fā)現(xiàn) 目前公司項(xiàng)目使用的注冊(cè)中心主要是Spring Cloud Alibaba的Nacos做的注冊(cè)中心和配置中心。并且Nacos使用了Ribbon作為默認(rèn)的負(fù)載均衡器。但是相當(dāng)于將Ribbon的負(fù)載均衡給透明化了,日常開發(fā)明面上是看不到

    2024年02月14日
    瀏覽(27)
  • Ribbon:Spring Cloud負(fù)載均衡與服務(wù)調(diào)用組件

    Ribbon:Spring Cloud負(fù)載均衡與服務(wù)調(diào)用組件

    負(fù)載均衡? Ribbon實(shí)現(xiàn)服務(wù)調(diào)用? Ribbon實(shí)現(xiàn)負(fù)載均衡? 切換負(fù)載均衡策略? 定制負(fù)載均衡策略? 負(fù)載均衡 負(fù)載均衡(Load Balance),將用戶的請(qǐng)求平分到多個(gè)服務(wù)器上運(yùn)行,以擴(kuò)展服務(wù)器帶寬、增強(qiáng)數(shù)據(jù)處理能力、增加吞吐量、提高網(wǎng)絡(luò)的可用性和靈活性的目的。 服務(wù)端負(fù)載

    2024年02月03日
    瀏覽(30)
  • Spring Cloud之負(fù)載均衡與服務(wù)調(diào)用(Ribbon)

    Spring Cloud之負(fù)載均衡與服務(wù)調(diào)用(Ribbon)

    目錄 Ribbon 簡(jiǎn)介 負(fù)載均衡 簡(jiǎn)介 負(fù)載均衡方式 服務(wù)端負(fù)載均衡 工作原理 特點(diǎn) 客戶端負(fù)載均衡 工作原理 特點(diǎn) 對(duì)比 實(shí)現(xiàn) 負(fù)載均衡策略 切換負(fù)載均衡策略 定制負(fù)載均衡策略 超時(shí)與重試 單個(gè)服務(wù)配置 全局配置 服務(wù)調(diào)用 示例 ????????Ribbon 是 Netflix 公司發(fā)布的開源組件,其

    2024年02月08日
    瀏覽(19)
  • SpringCloud Ribbon中的7種負(fù)載均衡策略

    SpringCloud Ribbon中的7種負(fù)載均衡策略

    負(fù)載均衡通器常有兩種實(shí)現(xiàn)手段,一種是服務(wù)端負(fù)載均衡器,另一種是客戶端負(fù)載均衡器,而我們今天的主角 Ribbon 就屬于后者——客戶端負(fù)載均衡器。 服務(wù)端負(fù)載均衡器的問題是,它提供了更強(qiáng)的流量控制權(quán),但無法滿足不同的消費(fèi)者希望使用不同負(fù)載均衡策略的需求,而

    2024年02月11日
    瀏覽(26)
  • Spring Cloud 實(shí)戰(zhàn) | 解密負(fù)載均衡Ribbon底層原理,包含實(shí)戰(zhàn)源碼

    Spring Cloud 實(shí)戰(zhàn) | 解密負(fù)載均衡Ribbon底層原理,包含實(shí)戰(zhàn)源碼

    專欄集錦,大佬們可以收藏以備不時(shí)之需 Spring Cloud實(shí)戰(zhàn)專欄:https://blog.csdn.net/superdangbo/category_9270827.html Python 實(shí)戰(zhàn)專欄:https://blog.csdn.net/superdangbo/category_9271194.html Logback 詳解專欄:https://blog.csdn.net/superdangbo/category_9271502.html tensorflow專欄:https://blog.csdn.net/superdangbo/category_869

    2024年02月08日
    瀏覽(23)
  • Spring Cloud(Finchley版本)系列教程(二) 客戶端負(fù)載均衡Ribbon

    Spring Cloud(Finchley版本)系列教程(二) 客戶端負(fù)載均衡Ribbon

    Spring Cloud(Finchley版本)系列教程(二) 客戶端負(fù)載均衡Ribbon 目前主流的負(fù)載均衡方案有兩種,一種是集中式均衡負(fù)載,在消費(fèi)者與服務(wù)提供者之間使用獨(dú)立的代理方式進(jìn)行負(fù)載,比如F5、Nginx等。另一種則是客戶端自己做負(fù)載均衡,根據(jù)自己的請(qǐng)求做負(fù)載,Ribbon就屬于客戶端自己

    2024年02月09日
    瀏覽(47)
  • 4-Spring cloud之搭建Ribbon負(fù)載均衡——服務(wù)器上實(shí)操(下)

    4-Spring cloud之搭建Ribbon負(fù)載均衡——服務(wù)器上實(shí)操(下)

    我們?cè)谏掀恼碌幕A(chǔ)上繼續(xù)Ribbon的負(fù)載均衡,為了更清晰,再放一次架構(gòu)圖,如下: 關(guān)于圖的更多解釋,請(qǐng)看Ribbon負(fù)載均衡上篇。 關(guān)于上篇請(qǐng)看下面文章,如下: 3-Spring cloud之搭建Ribbon負(fù)載均衡——服務(wù)器上實(shí)操(上). Ribbon負(fù)載均衡的規(guī)則都定義在IRule接口中,而IRule有

    2024年02月12日
    瀏覽(16)
  • 云原生微服務(wù) 第五章 Spring Cloud Netflix Eureka集成負(fù)載均衡組件Ribbon

    云原生微服務(wù) 第五章 Spring Cloud Netflix Eureka集成負(fù)載均衡組件Ribbon

    第一章 Java線程池技術(shù)應(yīng)用 第二章 CountDownLatch和Semaphone的應(yīng)用 第三章 Spring Cloud 簡(jiǎn)介 第四章 Spring Cloud Netflix 之 Eureka 第五章 Spring Cloud Netflix 之 Ribbon Spring Cloud Ribbon 是一套基于 Netflix Ribbon 實(shí)現(xiàn)的客戶端負(fù)載均衡和服務(wù)調(diào)用工具,其主要功能是提供客戶端的負(fù)載均衡算法和服務(wù)

    2024年02月08日
    瀏覽(87)
  • Spring Cloud Alibaba全家桶(三)——微服務(wù)負(fù)載均衡器Ribbon與LoadBalancer

    Spring Cloud Alibaba全家桶(三)——微服務(wù)負(fù)載均衡器Ribbon與LoadBalancer

    本文為 微服務(wù)負(fù)載均衡器Ribbon與LoadBalancer 相關(guān)知識(shí),下邊將對(duì) 什么是Ribbon (包括: 客戶端的負(fù)載均衡 、 服務(wù)端的負(fù)載均衡 、 常見負(fù)載均衡算法 ), Nacos使用Ribbon , Ribbon內(nèi)核原理 (包括: Ribbon原理 , Ribbon負(fù)載均衡策略 , 饑餓加載 ), Spring Cloud LoadBalancer (包括:

    2024年02月02日
    瀏覽(31)
  • Spring Cloud LoadBalancer 負(fù)載均衡策略與緩存機(jī)制

    Spring Cloud LoadBalancer 負(fù)載均衡策略與緩存機(jī)制

    目錄 1. 什么是 LoadBalancer ? 2. 負(fù)載均衡策略的分類 2.1 常見的負(fù)載均衡策略 3. 為什么要學(xué)習(xí) Spring Cloud Balancer ? 4. Spring Cloud LoadBalancer 內(nèi)置的兩種負(fù)載均衡策略 4.1 輪詢負(fù)載均衡策略(默認(rèn)的) 4.2 隨機(jī)負(fù)載均衡策略 4.2.1 創(chuàng)建隨機(jī)負(fù)載均衡策略 ?4.2.2?設(shè)置隨機(jī)負(fù)載均衡策略

    2024年01月21日
    瀏覽(25)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包