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

SpringCloud之LoadBalancer負(fù)載均衡服務(wù)調(diào)用過程

 更新時(shí)間:2025年03月24日 15:38:51   作者:夢(mèng)塵(0_O)  
這篇文章主要介紹了SpringCloud之LoadBalancer負(fù)載均衡服務(wù)調(diào)用過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言

LoadBalancer是Ribbon的未來替換方案

一、LoadBalancer是什么?

LB負(fù)載均衡(Load Balance)是什么

  • 簡(jiǎn)單的說就是將用戶的請(qǐng)求平攤的分配到多個(gè)服務(wù)上,從而達(dá)到系統(tǒng)的HA(高可用)
  • 常見的負(fù)載均衡有軟件Nginx,LVS,硬件 F5等

spring-cloud-starter-loadbalancer組件是什么

  • Spring Cloud LoadBalancer是由SpringCloud官方提供的一個(gè)開源的、簡(jiǎn)單易用的客戶端負(fù)載均衡器,它包含在SpringCloud-commons中用它來替換了以前的Ribbon組件。
  • 相比較于Ribbon,SpringCloud LoadBalancer不僅能夠支持RestTemplate,還支持WebClient(WeClient是Spring Web Flux中提供的功能,可以實(shí)現(xiàn)響應(yīng)式異步請(qǐng)求)

官網(wǎng):http://docs.spring.io/spring-cloud-commons/reference/spring-cloud-commons/loadbalancer.html

客戶端負(fù)載和服務(wù)端負(fù)載區(qū)別:

  • Nginx是服務(wù)器負(fù)載均衡,客戶端所有請(qǐng)求都會(huì)交給nginx,然后由nginx實(shí)現(xiàn)轉(zhuǎn)發(fā)請(qǐng)求,即負(fù)載均衡是由服務(wù)端實(shí)現(xiàn)的。
  • loadbalancer本地負(fù)載均衡,在調(diào)用微服務(wù)接口時(shí)候,會(huì)在注冊(cè)中心上獲取注冊(cè)信息服務(wù)列表之后緩存到JVM本地,從而在本地實(shí)現(xiàn)RPC遠(yuǎn)程服務(wù)調(diào)用技術(shù)。

二、使用步驟

1、啟動(dòng)consul

詳見:SpringCloud--consul服務(wù)注冊(cè)與發(fā)現(xiàn)、配置管理、配置持久化

2、客戶端加入依賴

<!--loadbalancer-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

3、以服務(wù)名稱調(diào)用

public static final String PaymentSrv_URL = "http://cloud-payment-service";//服務(wù)注冊(cè)中心上的微服務(wù)名稱
@GetMapping(value = "/consumer/pay/get/info")
private String getInfoByConsul(){
   return restTemplate.getForObject(PaymentSrv_URL + "/pay/get/info", String.class);
}

用restTemplate調(diào)用服務(wù)時(shí),使用服務(wù)名稱調(diào)用后,在consul中注冊(cè)相同服務(wù)名稱的的服務(wù)會(huì)通過loadbalancer實(shí)現(xiàn)負(fù)載均衡,使得每個(gè)相同服務(wù)名稱的服務(wù)被訪問的次數(shù)平均。

三、負(fù)載均衡算法替換

1、 默認(rèn)算法輪詢(相同服務(wù)名下的所有服務(wù)枚舉調(diào)用)

  • restTemplate配置:
@Configuration
public class RestTemplateConfig {
    @Bean
    @LoadBalanced //按服務(wù)名稱調(diào)用時(shí)默認(rèn)負(fù)載均衡 要加上該注解支持負(fù)載均衡
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

2、替換隨機(jī)算法(相同服務(wù)名下的所有服務(wù)隨機(jī)調(diào)用)

  • restTemplate配置:
@Configuration
@LoadBalancerClient(
        //下面的value值大小寫一定要和consul里面的名字一樣,必須一樣
        value = "cloud-payment-service",configuration = RestTemplateConfig.class)
public class RestTemplateConfig
{
    @Bean
    @LoadBalanced //使用@LoadBalanced注解賦予RestTemplate負(fù)載均衡的能力
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

    @Bean
    ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
                                                            LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);

        return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
    }
}

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java實(shí)現(xiàn)微信公眾號(hào)發(fā)送模版消息

    java實(shí)現(xiàn)微信公眾號(hào)發(fā)送模版消息

    這篇文章以訂單推送為例,主要為大家詳細(xì)介紹了java實(shí)現(xiàn)微信公眾號(hào)發(fā)送模版消息,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • 解析SpringSecurity+JWT認(rèn)證流程實(shí)現(xiàn)

    解析SpringSecurity+JWT認(rèn)證流程實(shí)現(xiàn)

    這篇文章主要介紹了解析SpringSecurity+JWT認(rèn)證流程實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • java+io+swing實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    java+io+swing實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java+io+swing實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Flowable數(shù)據(jù)庫表分類及數(shù)據(jù)字典解析

    Flowable數(shù)據(jù)庫表分類及數(shù)據(jù)字典解析

    這篇文章主要介紹了Flowable數(shù)據(jù)庫表分類及數(shù)據(jù)字典解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Java編程中最基礎(chǔ)的文件和目錄操作方法詳解

    Java編程中最基礎(chǔ)的文件和目錄操作方法詳解

    這篇文章主要介紹了Java編程中最基礎(chǔ)的文件和目錄操作方法詳解,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11
  • 談?wù)凥ashmap的容量為什么是2的冪次問題

    談?wù)凥ashmap的容量為什么是2的冪次問題

    這篇文章主要介紹了談?wù)凥ashmap的容量為什么是2的冪次問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 面試必時(shí)必問的JVM 類加載機(jī)制詳解

    面試必時(shí)必問的JVM 類加載機(jī)制詳解

    這篇文章主要介紹了一文讀懂Jvm類加載機(jī)制,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-08-08
  • Java中Hashtable集合的常用方法詳解

    Java中Hashtable集合的常用方法詳解

    本篇文章給大家?guī)淼膬?nèi)容是關(guān)于Java中Hashtable集合的常用方法詳解,有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。下面我們就來學(xué)習(xí)一下吧
    2021-11-11
  • JAVA OutputStreamWriter流的實(shí)現(xiàn)

    JAVA OutputStreamWriter流的實(shí)現(xiàn)

    OutputStreamWriter是從字符流到字節(jié)流的橋接,它使用的字符集可以通過名稱指定,也可以明確指定,或者可以接受平臺(tái)的默認(rèn)字符集,本文詳細(xì)的介紹了JAVA OutputStreamWriter流的使用,感興趣的可以了解一下
    2021-06-06
  • Java中StringBuilder字符串類型的操作方法及API整理

    Java中StringBuilder字符串類型的操作方法及API整理

    Java中的StringBuffer類繼承于AbstractStringBuilder,用來創(chuàng)建非線程安全的字符串類型對(duì)象,下面即是對(duì)Java中StringBuilder字符串類型的操作方法及API整理
    2016-05-05

最新評(píng)論