亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringCloud中的Ribbon負(fù)載均衡器詳細(xì)解析

 更新時間:2024年01月31日 10:12:51   作者:卷不動躺不平的粥  
這篇文章主要介紹了SpringCloud中的Ribbon負(fù)載均衡器詳細(xì)解析,Ribbon 是一個基于 HTTP 和 TCP 的客戶端負(fù)載均衡工具,它基于 Netflix Ribbon 實現(xiàn),通過封裝可以讓我們輕松地將面向服務(wù)的 REST 模版請求自動轉(zhuǎn)換成客戶端負(fù)載均衡的服務(wù)調(diào)用,需要的朋友可以參考下

一、Ribbon的簡介

1.1 簡介

Spring Cloud Ribbon 是一個基于 HTTP 和 TCP 的客戶端負(fù)載均衡工具,它基于 Netflix Ribbon 實現(xiàn)。通過 Spring Cloud 的封裝,可以讓我們輕松地將面向服務(wù)的 REST 模版請求自動轉(zhuǎn)換成客戶端負(fù)載均衡的服務(wù)調(diào)用。

目前主流的負(fù)載方案分為以下兩種:

  • 集中式負(fù)載均衡,在消費(fèi)者和服務(wù)提供方中間使用獨(dú)立的代理方式進(jìn)行負(fù)載,有硬件的(比如 F5),也有軟件的(比如 Nginx)。
  • 客戶端自己做負(fù)載均衡,根據(jù)自己的請求情況做負(fù)載,Ribbon 就屬于客戶端自己做負(fù)載。

1.2 引言

Robbin是幫助我們實現(xiàn)服務(wù)與服務(wù)之間的負(fù)載均衡。

  • 客戶端負(fù)載均衡:customer客戶端模塊,將2個Search模塊信息全部拉取到本地的緩存,在customer中自己做一個負(fù)載均衡的策略,選中某一個服務(wù)。
  • 服務(wù)端負(fù)載均衡:在注冊中心中,直接根據(jù)你指定的負(fù)載均衡策略,幫你選中一個指定的服務(wù)器信息,并返回。

二、快速入門

2.1 啟動兩個Search模塊

通過 Run/Debug Configurations 啟動兩個 Search模塊。

2.2 導(dǎo)入Ribbon相關(guān)依賴

在 customer 中導(dǎo)入 Ribbon 相關(guān)依賴。

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>

2.3 整合 RestTemplate 和 Ribbon

在注入 RestTemplate 的方法上添加 @LoadBalanced 注解,即可整合 RestTemplate 和 Ribbon 。

//@LoadBalanced 將RestTemplate和Robbin整合
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
    return new RestTemplate();
}

2.4 訪問 Search

通過整合了 Ribbon 的 RestTemplate 去訪問Search (原來的 ip:port 現(xiàn)在可以用服務(wù)名代替)。

@GetMapping("/customer")
public String customer() {
    String result = restTemplate.getForObject("http://SEARCH/search", String.class);
    return result;
}

三、Ribbon 的負(fù)載均衡

Ribbon 作為一款客戶端負(fù)載均衡框架默認(rèn)的負(fù)載策略是輪詢,同時也提供了很多其他的策略,能夠讓用戶根據(jù)自身的業(yè)務(wù)需求進(jìn)行選擇。

3.1 Ribbon負(fù)載均衡簡介

BestAvailabl

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

AvailabilityFilteringRule

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

ZoneAvoidanceRule

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

RandomRule(隨機(jī)策略)

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

RoundRobinRule(輪詢策略)

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

RetryRule

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

ResponseTimeWeightedRule

作用同 WeightedResponseTimeRule,ResponseTime-Weighted Rule 后來改名為 WeightedResponseTimeRule。

WeightedResponseTimeRule

默認(rèn)會采用輪詢的策略,,根據(jù)響應(yīng)時間會自動分配一個 Weight(權(quán)重),響應(yīng)時間越長,Weight 越小,被選中的可能性越低。

3.2 Ribbon負(fù)載均衡的使用

3.2.1 采用注解的方式實現(xiàn)負(fù)載均衡

在 Ribbon Client 端注入策略的對象即可。

//配置robbinRule策略
@Bean
public IRule robbinRule(){
    return new RandomRule();
}

3.2.2 采用配置文件的方式實現(xiàn)負(fù)載均衡

#指定具體服務(wù)的負(fù)載均衡策略
SEARCH:        #編寫服務(wù)名稱
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.WeightedResponseTimeRule  #具體負(fù)載均衡使用的類

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

相關(guān)文章

  • Can''t use Subversion command line client:svn 報錯處理

    Can''t use Subversion command line client:svn 報錯處理

    這篇文章主要介紹了Can't use Subversion command line client:svn 報錯處理的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • Spring中@Async注解執(zhí)行異步任務(wù)的方法

    Spring中@Async注解執(zhí)行異步任務(wù)的方法

    在業(yè)務(wù)處理中,有些業(yè)務(wù)使用異步的方式更為合理,這篇文章主要介紹了Spring中@Async注解執(zhí)行異步任務(wù)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • spring的data派生查詢機(jī)制的實現(xiàn)

    spring的data派生查詢機(jī)制的實現(xiàn)

    SpringData的派生查詢是一種通過方法名約定自動生成數(shù)據(jù)庫查詢的機(jī)制,無需手動編寫SQL或JPQL,下面就來介紹一下spring data派生查詢的實現(xiàn),感興趣的可以了解一下
    2025-03-03
  • Java類成員訪問權(quán)限控制知識總結(jié)

    Java類成員訪問權(quán)限控制知識總結(jié)

    這篇文章主要介紹了Java類成員訪問權(quán)限控制知識總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • Java求余%操作引發(fā)的一連串故事

    Java求余%操作引發(fā)的一連串故事

    取模運(yùn)算與取余運(yùn)算兩個概念有重疊的部分但又不完全一致。主要的區(qū)別在于對負(fù)整數(shù)進(jìn)行除法運(yùn)算時操作不同。本文重點(diǎn)給大家介紹Java求余%操作引發(fā)的一連串故事,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • Mybatis自關(guān)聯(lián)查詢一對多查詢的實現(xiàn)示例

    Mybatis自關(guān)聯(lián)查詢一對多查詢的實現(xiàn)示例

    這篇文章主要介紹了Mybatis自關(guān)聯(lián)查詢一對多查詢的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Springboot下使用Redis管道(pipeline)進(jìn)行批量操作

    Springboot下使用Redis管道(pipeline)進(jìn)行批量操作

    本文主要介紹了Spring?boot?下使用Redis管道(pipeline)進(jìn)行批量操作,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • SpringBoot基于Mybatis攔截器和JSqlParser實現(xiàn)數(shù)據(jù)隔離

    SpringBoot基于Mybatis攔截器和JSqlParser實現(xiàn)數(shù)據(jù)隔離

    本文將介紹如何在 Spring Boot 項目中利用Mybatis的強(qiáng)大攔截器機(jī)制結(jié)合JSqlParser,一個功能豐富的 SQL 解析器,來輕松實現(xiàn)數(shù)據(jù)隔離的目標(biāo),本文根據(jù)示例展示如何根據(jù)當(dāng)前的運(yùn)行環(huán)境來實現(xiàn)數(shù)據(jù)隔離,需要的朋友可以參考下
    2024-04-04
  • Java實現(xiàn)IP地址到二進(jìn)制的轉(zhuǎn)換

    Java實現(xiàn)IP地址到二進(jìn)制的轉(zhuǎn)換

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)IP地址到二進(jìn)制的轉(zhuǎn)換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Java實現(xiàn)統(tǒng)計字符串出現(xiàn)的次數(shù)

    Java實現(xiàn)統(tǒng)計字符串出現(xiàn)的次數(shù)

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)統(tǒng)計字符串出現(xiàn)的次數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10

最新評論