91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringCloud?LoadBalancer自定義負載均衡器怎么使用

發布時間:2023-04-17 10:22:51 來源:億速云 閱讀:153 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“SpringCloud LoadBalancer自定義負載均衡器怎么使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“SpringCloud LoadBalancer自定義負載均衡器怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

Spring Cloud LoadBalancer 幫開發者已經實現了RoundRobinLoadBalancer、RandomLoadBalancer,分別是輪訓和隨機,默認實現為輪訓。

即讓是負載均衡組件,那必然有默認實現,也必然有擴展接口暴露給開發者。所以第一步肯定是介紹抽象接口。

// 負載均衡的標志性接口,繼承ReactorLoadBalancer接口
// 本接口無任何接口增強,僅僅作為一個標志性接口。
public interface ReactorServiceInstanceLoadBalancer extends ReactorLoadBalancer<ServiceInstance> 
// 在Spring Cloud高版本中大部分組件采用了Reacotr框架(有一說一,閱讀性極差!!)
// 這里定義了一個選擇的抽象方法。
public interface ReactorLoadBalancer<T> extends ReactiveLoadBalancer<T> {
	Mono<Response<T>> choose(Request request);
	default Mono<Response<T>> choose() {
		return choose(REQUEST);
	}
}

這里有涉及到Reactor框架,不過完全可以當黑盒使用。接口非常的簡單就一個choose方法,所以接下來我們只需要實現此接口。

@LoadBalancerClient(value = "deptmanagecloud-provider", configuration = MyConfig.class)
public class MyConfig {
    // 配置負載均衡策略
    @Bean
    public ReactorLoadBalancer<ServiceInstance> myLB(Environment environment, LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new MyLB(
                loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class));
    }
}

這里有部分邏輯,讀者完全可以當作黑盒暫時不需要去理解。只需要明白從注冊中心拿到注冊表以后會執行getInstanceResponse方法,只需要實現自定義負載均衡策略的邏輯即可,好比我這里的邏輯是永遠只調用一個服務(當然,這完全扯淡,僅僅是Demo無須太關心)

既然我們把自定義負載均衡策略寫好了,那么,怎么告訴Spring呢?肯定需要注入給Spring。

@LoadBalancerClient(value = "deptmanagecloud-provider", configuration = MyConfig.class)
public class MyConfig {
    // 配置負載均衡策略
    @Bean
    public ReactorLoadBalancer<ServiceInstance> myLB(Environment environment, LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new MyLB(
                loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class));
    }
}

這里需要?上@LoadBalancerClient注解,value為調用方的服務名,configuration為配置類

讀到這里,這篇“SpringCloud LoadBalancer自定義負載均衡器怎么使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泉州市| 平遥县| 甘孜县| 苗栗市| 西平县| 湖口县| 清流县| 策勒县| 西林县| 柳河县| 安西县| 辽中县| 阜新| 青岛市| 昌黎县| 成都市| 托克托县| 揭东县| 岐山县| 克什克腾旗| 甘孜| 虹口区| 慈利县| 石嘴山市| 成安县| 霍山县| 罗田县| 新野县| 四川省| 临沂市| 盘山县| 宁城县| 临夏市| 红安县| 鄂伦春自治旗| 萍乡市| 平顺县| 苗栗县| 金寨县| 铜川市| 滦平县|