SpringCloud Ribbon 負(fù)載均衡的實(shí)現(xiàn)
前言
Ribbon是一個(gè)客戶端負(fù)載均衡器,它提供了對(duì)HTTP和TCP客戶端的行為的大量控制。我們?cè)谏掀痛粒?a target="_blank" href="http://www.dhdzp.com/article/154425.htm">SpringCloud系列——Feign 服務(wù)調(diào)用)已經(jīng)實(shí)現(xiàn)了多個(gè)服務(wù)之間的Feign調(diào)用,服務(wù)消費(fèi)者調(diào)用服務(wù)提供者,本文記錄Feign調(diào)用Ribbon負(fù)載均衡的服務(wù)提供者
GitHub地址:https://github.com/Netflix/ribbon
服務(wù)提供者
服務(wù)提供者有兩個(gè),實(shí)際上可以看做只有一個(gè),因?yàn)檫@兩個(gè)只有端口不同
maven引入Ribbon
<!-- Ribbon -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
創(chuàng)建RibbonConfig文件,主類添加@RibbonClient(name = "RibbonConfig", configuration = RibbonConfig.class),我這里偷懶,直接在主類中創(chuàng)建內(nèi)部類
@EnableEurekaClient
@RibbonClient(name = "RibbonConfig", configuration = RibbonConfig.class)
@SpringBootApplication
public class SpringbootSpringdataJpaApplication{
public static void main(String[] args) {
SpringApplication.run(SpringbootSpringdataJpaApplication.class, args);
}
}
@Configuration
class RibbonConfig {
@Bean
public IRule ribbonRule(){
return new RandomRule(); //分配策略:隨機(jī)選擇一個(gè)server
// return new BestAvailableRule(); //分配策略:選擇一個(gè)最小的并發(fā)請(qǐng)求的server,逐個(gè)考察Server,如果Server被tripped了,則忽略
// return new RoundRobinRule(); //分配策略:輪詢選擇,輪詢index,選擇index對(duì)應(yīng)位置的server
// return new WeightedResponseTimeRule(); //分配策略:根據(jù)響應(yīng)時(shí)間分配一個(gè)weight(權(quán)重),響應(yīng)時(shí)間越長(zhǎng),weight越小,被選中的可能性越低
// return new ZoneAvoidanceRule(); //分配策略:復(fù)合判斷server所在區(qū)域的性能和server的可用性選擇server
// return new RetryRule(); //分配策略:對(duì)選定的負(fù)載均衡策略機(jī)上重試機(jī)制,在一個(gè)配置時(shí)間段內(nèi)當(dāng)選擇server不成功,則一直嘗試使用subRule的方式選擇一個(gè)可用的server
}
@Bean
public IPing ribbonPing() {
return new PingUrl();
}
@Bean
public ServerListSubsetFilter serverListFilter() {
ServerListSubsetFilter filter = new ServerListSubsetFilter();
return filter;
}
}
下表顯示了Spring Cloud Netflix默認(rèn)為Ribbon提供的bean:

官網(wǎng)例子:

我們添加一個(gè)測(cè)試接口
@RestController
@RequestMapping("/user")
public class UserController {
@RequestMapping("/ribbon")
public String ribbon() {
return "springdatejpa -- 我的端口是:10088";
}
}
第二個(gè)服務(wù)提供者也是這樣配置,注意:應(yīng)用名要相同(spring.application.name=springdatejpa);端口不同;
服務(wù)消費(fèi)者
服務(wù)消費(fèi)者使用Feign調(diào)用,無(wú)需做任何修改,F(xiàn)eign已經(jīng)使用Ribbon。具體配置請(qǐng)戳:SpringCloud系列——Feign 服務(wù)調(diào)用
@FeignClient(name = "springdatejpa", path = "/user/")
public interface MyspringbootFeign {
@RequestMapping("/ribbon")
String ribbon();
}
/**
* feign調(diào)用
*/
@GetMapping("feign/ribbon")
String ribbon(){
return myspringbootFeign.ribbon();
}
效果
啟動(dòng)所有項(xiàng)目,我們注冊(cè)了三個(gè)服務(wù),其中:
有兩個(gè)服務(wù)名稱相同、處理的業(yè)務(wù)相同、端口不同,這兩臺(tái)作為服務(wù)提供者(可看做是一個(gè)“小集群”);
另一個(gè)是服務(wù)消費(fèi)者(Feign調(diào)用);

消費(fèi)者不斷調(diào)用,Ribbon會(huì)從注冊(cè)中心的服務(wù)列表拉取實(shí)例集合進(jìn)行負(fù)載均衡調(diào)用背后的服務(wù)提供者

后記
Ribbon負(fù)載均衡已經(jīng)可以實(shí)現(xiàn),更多配置請(qǐng)看官方文檔
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- springcloud gateway如何實(shí)現(xiàn)路由和負(fù)載均衡
- SpringCloud 服務(wù)負(fù)載均衡和調(diào)用 Ribbon、OpenFeign的方法
- 詳解SpringCloud Ribbon 負(fù)載均衡通過(guò)服務(wù)器名無(wú)法連接的神坑
- SpringCloud與Consul集成實(shí)現(xiàn)負(fù)載均衡功能
- SpringCloud Alibaba 基本開(kāi)發(fā)框架搭建過(guò)程
- Alibaba?SpringCloud集成Nacos、openFeign實(shí)現(xiàn)負(fù)載均衡的解決方案
相關(guān)文章
關(guān)于SpringBoot改動(dòng)后0.03秒啟動(dòng)的問(wèn)題
這篇文章主要介紹了SpringBoot改動(dòng)后0.03秒啟動(dòng),本文結(jié)合示例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
基于 SpringBoot 實(shí)現(xiàn) MySQL 讀寫(xiě)分離的問(wèn)題
這篇文章主要介紹了基于 SpringBoot 實(shí)現(xiàn) MySQL 讀寫(xiě)分離的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
java web項(xiàng)目里ehcache.xml介紹
java web項(xiàng)目里ehcache.xml介紹,需要的朋友可以參考一下2013-03-03
java 學(xué)習(xí)筆記(入門(mén)篇)_java的安裝與配置
學(xué)習(xí)Java已經(jīng)很長(zhǎng)時(shí)間了,由于基礎(chǔ)不好遇到問(wèn)題就無(wú)從下手,所以,打算寫(xiě)Java的隨手筆記來(lái)鞏固基礎(chǔ),加強(qiáng)學(xué)習(xí),接下來(lái)講解java的安裝,配置等,感興趣的朋友可以參考下2013-01-01
springboot?sleuth?日志跟蹤問(wèn)題記錄
Spring?Cloud?Sleuth是一個(gè)在應(yīng)用中實(shí)現(xiàn)日志跟蹤的強(qiáng)有力的工具,使用Sleuth庫(kù)可以應(yīng)用于計(jì)劃任務(wù)?、多線程服務(wù)或復(fù)雜的Web請(qǐng)求,尤其是在一個(gè)由多個(gè)服務(wù)組成的系統(tǒng)中,這篇文章主要介紹了springboot?sleuth?日志跟蹤,需要的朋友可以參考下2023-07-07
關(guān)于批量插入或更新數(shù)據(jù)(MyBatis-plus框架)
這篇文章主要介紹了關(guān)于批量插入或更新數(shù)據(jù)(MyBatis-plus框架),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Java Swing JPasswordField密碼框的實(shí)現(xiàn)示例
這篇文章主要介紹了Java Swing JPasswordField密碼框的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12

