欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Cloud 系列之負(fù)載均衡 Ribbon的示例代碼

 更新時(shí)間:2020年11月06日 09:44:35   作者:Demo_Null  
Ribbon 是 Netflix 發(fā)布的負(fù)載均衡器,它有助于控制 HTTP 和 TCP 客戶端的行為。這篇文章主要介紹了Spring Cloud 系列之負(fù)載均衡 Ribbon的示例代碼,需要的朋友可以參考下

1.1 簡(jiǎn)介

1.1.1 概述

  Ribbon 是 Netflix 發(fā)布的負(fù)載均衡器,它有助于控制 HTTP 和 TCP 客戶端的行為。為 Ribbon 配置服務(wù)提供者地址列表后,Ribbon 就可基于某種負(fù)載均衡算法,自動(dòng)地幫助服務(wù)消費(fèi)者去請(qǐng)求。Ribbon 默認(rèn)為我們提供了很多的負(fù)載均衡算法,例如輪詢、隨機(jī)等。當(dāng)然,我們也可為 Ribbon 實(shí)現(xiàn)自定義的負(fù)載均衡算法。Ribbon 現(xiàn)在已經(jīng)進(jìn)入維護(hù)狀態(tài),但目前仍在大規(guī)模使用,Spring Cloud 準(zhǔn)備使用 LoadBalancer 作為 Ribbon 的替換方案。

1.1.2 相關(guān)依賴

  因?yàn)楝F(xiàn)在的注冊(cè)中心幫我們引入了 Ribbon 我們不需要再次引入就可以直接使用,當(dāng)然也可以再引入一次沒(méi)有影響。

在這里插入圖片描述

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

1.2 簡(jiǎn)單使用

1.2.1 搭建項(xiàng)目

eureka 項(xiàng)目

1.2.2 開(kāi)啟負(fù)載均衡

  開(kāi)啟負(fù)載均衡非常簡(jiǎn)單,只需要在 RestTemplate 的配置方法上加上 @LoadBalanced 注解即可使用最簡(jiǎn)單的輪詢。

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/10/29
 * @description 消費(fèi)者啟動(dòng)類
 */
@SpringBootApplication
@EnableDiscoveryClient
public class ConsumerApplication {
 public static void main(String[] args) {
  SpringApplication.run(ConsumerApplication.class, args);
 }
 
 @Bean
 @LoadBalanced
 public RestTemplate getRestTemplate() {
  return new RestTemplate();
 }
}

1.2.3 使用負(fù)載均衡

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/10/29
 * @description
 */
@RestController
@RequestMapping("/consumer")
public class ConsumerController {

 @Autowired
 private DiscoveryClient discoveryClient;

 @Autowired
 private RestTemplate restTemplate;

 @GetMapping("/go")
 public void go() {
  List<ServiceInstance> providerServer = discoveryClient.getInstances("ProviderServer");

  if (0 == providerServer.size()) {
   return;
  }

  ServiceInstance serviceInstance = providerServer.get(0);
  String url = serviceInstance.getUri() + "/provider/get";
  System.out.println(url + " --- ");
  String str = restTemplate.getForObject(url, String.class);
  System.out.println(str);

 }
}

  喔嚯!報(bào)錯(cuò)了,明明可以訪問(wèn)到為什么會(huì)報(bào)找不到實(shí)例呢?這是應(yīng)為咱們使用 DiscoveryClient 直接獲取到了服務(wù)提供者集群中某一個(gè)的地址,然后讓 RestTemplate 去進(jìn)行負(fù)載均衡。我們都已經(jīng)拿到了準(zhǔn)確地址再怎么進(jìn)行負(fù)載均衡?所以我們這里不能使用 IP 要使用服務(wù)名稱。

在這里插入圖片描述
在這里插入圖片描述

@RestController
@RequestMapping("/consumer")
public class ConsumerController {

 @Autowired
 private RestTemplate restTemplate;


 @GetMapping("/go")
 public void go() {
  String url = "http://ProviderServer/provider/get";

  String str = restTemplate.getForObject(url, String.class);
  System.out.println(str);
 }
}

修改完畢之后就可以看到服務(wù)提供者是輪換進(jìn)行提供服務(wù)的

在這里插入圖片描述

1.3 替換負(fù)載均衡策略

1.3.1 自帶負(fù)載均衡策略

在這里插入圖片描述

策略名 策略描述
RoundRobinRule 輪詢選擇 server
RandomRule 隨機(jī)選擇一個(gè) serve
RetryRule 先按輪詢策略獲取服務(wù),如果獲取服務(wù)失敗則在指定時(shí)間內(nèi)重試,獲取可用服務(wù)
BestAvailableRule 會(huì)先過(guò)濾由于多次訪問(wèn)故障而處于斷路器跳閘狀態(tài)的服務(wù),然后選擇一個(gè)并發(fā)量最小的服務(wù)
AvailabilityFilteringRule 會(huì)優(yōu)先過(guò)濾故障實(shí)例,再選擇并發(fā)較小的實(shí)例
WeightedResponseTimeRule 對(duì)輪詢的擴(kuò)展,響應(yīng)速度越快的實(shí)例選擇比重權(quán)越大,越容易被選擇
ZoneAvoidanceRule 復(fù)合判斷 server 所在區(qū)域的性能和 server 的可用性選擇 server

1.3.2 使用配置類

  官方文檔明確警告,這個(gè)自定義配置類不能放在 @ComponedtScan 所掃描的當(dāng)前包下以及子包下,否則我們自定義的這個(gè)配置類就會(huì)被所有的 Ribbon 客戶端所共享。即在 Spring Boot 主程序掃描的包外定義配置類或在與 Spring Boot 主程序的同一級(jí)目錄但在排除掃描。配置類創(chuàng)建完畢后為 Spring Boo 主程序添加 @RibbonClient 注解引入配置類,用 name 屬性來(lái)指定調(diào)用的服務(wù)名稱,configuration 屬性指定自定義配置類

@Configuration
public class MyRibbonRule {

 @Bean
 public IRule ribbonRule() {
  return new RandomRule();
 }
}
@SpringBootApplication
@EnableDiscoveryClient
// 用 name 來(lái)指定調(diào)用的服務(wù)名稱,configuration 指定自定義配置類
@RibbonClient(name = "ProviderServer", configuration = MyRibbonRule.class)
public class ConsumerApplication {

 public static void main(String[] args) {
  SpringApplication.run(ConsumerApplication.class, args);
 }

 @Bean
 @LoadBalanced
 public RestTemplate getRestTemplate() {
  return new RestTemplate();
 }
}

在這里插入圖片描述

1.3.3 配置文件

# 這種配置的優(yōu)先級(jí)低于配置類
# 想要調(diào)用的服務(wù)名稱,即服務(wù)提供者名稱
ProviderServer:
 ribbon:
 NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

在這里插入圖片描述

源碼

到此這篇關(guān)于Spring Cloud 系列之負(fù)載均衡 Ribbon的示例代碼的文章就介紹到這了,更多相關(guān)Spring Cloud 負(fù)載均衡 Ribbon內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java CRM系統(tǒng)用戶登錄功能實(shí)現(xiàn)代碼實(shí)例

    Java CRM系統(tǒng)用戶登錄功能實(shí)現(xiàn)代碼實(shí)例

    這篇文章主要介紹了Java CRM系統(tǒng)用戶登錄功能實(shí)現(xiàn)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Java并發(fā)編程之原子變量與非阻塞同步機(jī)制

    Java并發(fā)編程之原子變量與非阻塞同步機(jī)制

    這篇文章主要介紹了Java并發(fā)編程之原子變量與非阻塞同步機(jī)制,本文講解了非阻塞算法、悲觀技術(shù)、樂(lè)觀技術(shù)、CAS操作、原子變量、性能比較:鎖與原子變量等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • Java項(xiàng)目工程代碼深度刨析總結(jié)

    Java項(xiàng)目工程代碼深度刨析總結(jié)

    一個(gè)項(xiàng)目工程里的代碼是怎樣的呢?對(duì)于初學(xué)者或者沒(méi)有參與過(guò)項(xiàng)目的零經(jīng)驗(yàn)同學(xué)這都是未知且讓人好奇的,本篇文章帶你一探究竟,踏入真實(shí)項(xiàng)目的大門
    2022-08-08
  • Hadoop源碼分析五hdfs架構(gòu)原理剖析

    Hadoop源碼分析五hdfs架構(gòu)原理剖析

    本篇是Hadoop源碼分析系列文章第五篇,主要介紹Hadoop的hdfs架構(gòu)原理剖析,后續(xù)本系列文章會(huì)持續(xù)更新,有需要的朋友可以借鑒參考下
    2021-09-09
  • 簡(jiǎn)單談?wù)凧ava中的棧和堆

    簡(jiǎn)單談?wù)凧ava中的棧和堆

    堆和棧都是Java用來(lái)在RAM中存放數(shù)據(jù)的地方,下面這篇文章主要給大家介紹了關(guān)于Java中棧和堆的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-11-11
  • Java編程實(shí)現(xiàn)比對(duì)兩個(gè)文本文件并標(biāo)記相同與不同之處的方法

    Java編程實(shí)現(xiàn)比對(duì)兩個(gè)文本文件并標(biāo)記相同與不同之處的方法

    這篇文章主要介紹了Java編程實(shí)現(xiàn)比對(duì)兩個(gè)文本文件并標(biāo)記相同與不同之處的方法,涉及java針對(duì)文本文件的讀取、遍歷、判斷等相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • 在webservice里調(diào)用耗時(shí)方法出錯(cuò)的解決方案

    在webservice里調(diào)用耗時(shí)方法出錯(cuò)的解決方案

    這篇文章主要介紹了在webservice里調(diào)用耗時(shí)方法出錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 解析Java和IDEA中的文件打包問(wèn)題

    解析Java和IDEA中的文件打包問(wèn)題

    這篇文章主要介紹了Java和IDEA中的文件打包問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-07-07
  • SpringBoot安全策略開(kāi)發(fā)之集成數(shù)據(jù)傳輸加密

    SpringBoot安全策略開(kāi)發(fā)之集成數(shù)據(jù)傳輸加密

    這篇文章主要介紹了SpringBoot集成數(shù)據(jù)傳輸加密,近期在對(duì)開(kāi)發(fā)框架安全策略方面進(jìn)行升級(jí)優(yōu)化,提供一些通用場(chǎng)景的解決方案,本文針對(duì)前后端數(shù)據(jù)傳輸加密進(jìn)行簡(jiǎn)單的分享
    2023-01-01
  • SpringBoot @Autowired注入為空的情況解讀

    SpringBoot @Autowired注入為空的情況解讀

    這篇文章主要介紹了SpringBoot @Autowired注入為空的情況解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評(píng)論