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

SpringCloud筆記(Hoxton)Netflix之Ribbon負載均衡示例代碼

 更新時間:2022年06月01日 11:16:41   作者:叮叮襠  
這篇文章主要介紹了SpringCloud筆記HoxtonNetflix之Ribbon負載均衡,Ribbon是管理HTTP和TCP服務(wù)客戶端的負載均衡器,Ribbon具有一系列帶有名稱的客戶端(Named?Client),對SpringCloud?Ribbon負載均衡相關(guān)知識感興趣的朋友一起看看吧

Ribbon使用

  • Ribbon是管理HTTP和TCP服務(wù)客戶端的負載均衡器,Ribbon具有一系列帶有名稱的客戶端(Named Client),也就是帶有名稱的Ribbon客戶端(Ribbon Client)。
  • 每個客戶端由可配置的組件構(gòu)成,負責一類服務(wù)的調(diào)用請求。SpringCloud通RibbonClientConfiguration 為每個Ribbon客戶端創(chuàng)建ApplicationContext上下文來進行組件裝配。Ribbon作為SpringCloud的負載均衡機制的實現(xiàn),可以與OpenFeign和RestTemplate進行無縫對接,讓二者具有負載均衡的能力。

負載均衡

  • 當系統(tǒng)面臨大量的用戶訪問,負載過高的時候,通常會增加服務(wù)器數(shù)量來進行橫向擴展,多個服務(wù)器的負載需要均衡,以免出現(xiàn)服務(wù)器負載不均衡,部分服務(wù)器負載較大,部分服務(wù)器負載較小的情況 通過負載均衡,使得集群中服務(wù)器的負載保持在穩(wěn)定高效的狀態(tài),從而提高整個系統(tǒng)的處理能力。
  • 系統(tǒng)的負載均衡分為軟件負載均衡和硬件負載均衡,軟件負載均衡使用獨立的負載均衡程序或系統(tǒng)自帶的負載均衡模塊完成對請求的分配派發(fā),硬件負載均衡通過特殊的硬件設(shè)備進行負載均衡的調(diào)配。
  • 軟負載均衡一般分為兩種類型,基于DNS負載均衡和基于IP的負載均衡。利用DNS 實現(xiàn)負載均衡,就是在DNS服務(wù)器配置多個A記錄,不同的 DNS請求解析到不同IP地址?;贗P的負載均衡根據(jù)請求的IP 行負載均衡,LVS就是具有代表性的基于IP負載均衡實現(xiàn)。
  • Ribbon使用的是客戶端負載均衡,客戶端負載均衡和服務(wù)端負載均衡最大的區(qū)別在于服務(wù)端地址列表的存儲位置,在客戶端負載均衡中,所有的客戶端節(jié)點都有一份自己要訪問的服務(wù)端地址列表,這些列表統(tǒng)統(tǒng)都是從服務(wù)注冊中心獲取的;而在服務(wù)端負載均衡中,客戶端節(jié)點只知道單一服務(wù)代理的地址,服務(wù)代理則知道所有服務(wù)端的地址。在SpringCloud中我們?nèi)绻胍褂每蛻舳素撦d均衡,可以使用@LoadBalanced注解,這樣客戶端在發(fā)起請求的時候會根據(jù)負載均衡策略從服務(wù)端列表中選擇一個服務(wù)端,向該服務(wù)端發(fā)起網(wǎng)絡(luò)請求,從而實現(xiàn)負載均衡。

代碼示例

注冊中心

這里是Eureka作為服務(wù)注冊中心,為OpenFeign提供服務(wù)端信息的獲取,比如說服務(wù)的IP地址和端口,使用前面搭建好的項目(eureka-server)。

Provider

在idea中新建兩個項目運行主類,選擇前面創(chuàng)建好的項目(eureka-provider)。

在這里插入圖片描述

設(shè)置不同運行主類,使用不同端口號,然后啟動三個不同端口號的provider。

在這里插入圖片描述

接口實現(xiàn)

調(diào)用不同的服務(wù)端,會返回對應服務(wù)端的接口。

@RestController
@RequestMapping("/api")
public class PoroviderController {

    @Value("${server.port}")
    private String serverPort;

    @PostMapping("/sayHello")
    public String sayHello(String name) {
        return "我是服務(wù)端" + serverPort + ",你好" + name;
    }
}

Consumer

新建一個spring-boot工程,取名為consumer-ribbon,在pom文件引入ribbon需要的依賴。

添加依賴

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

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

配置端口、注冊中心等

server:
  port: 8091
  servlet:
    context-path: /ribbon
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
  instance:
    status-page-url-path: ${server.servlet.context-path}/info
    health-check-url-path: ${server.servlet.context-path}/health
spring:
  application:
    name: consumer-ribbon
  • 負載均衡策略 SpringCloud為客戶端負載均衡創(chuàng)建了特定的注解@LoadBalanced,我們只需要使用該注解修飾創(chuàng)建RestTemplate實例的@Bean函數(shù),SpringCloud就會讓RestTemplate使用相關(guān)的負載均衡策略,默認情況下使用Ribbon。
  • 除了@LoadBalanced之外,Ribbon還提供@RibbonClient注解。該注解可以為Ribbon客戶端聲明名稱和自定義配置。 name屬性可以設(shè)置客戶端的名稱, configuration屬性則會設(shè)置Ribbon相關(guān)的自定義配 類。
@Configuration
public class RestTemplateConfig {

    /**
     * @return org.springframework.web.client.RestTemplate
     * @description 注入一個可以進行負載均衡的RestTemple用于服務(wù)問調(diào)用
     * @author fengfan
     * @date 2022/5/18 14:43
     */
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

}

yml配置負載均衡策略

# 配置的方式設(shè)置Ribbon的負載均衡策略
EUREKA-PROVIDER: # 設(shè)置服務(wù)提供方的應用名稱
  ribbon:
    NFloadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 策略類(全路徑名)

代碼方式配置負載均衡策略

@Configuration
public class RibbonConfig {

    /**
     * @return com.netflix.loadbalancer.IRule
     * @description 配置隨機負載策略
     * @author fengfan
     * @date 2022/5/20 16:04
     */
    @Bean
    public IRule iRule(){
        return new RandomRule();
    }
}

@SpringBootApplication
@EnableEurekaClient
@RibbonClient(name = "consumer-ribbon", configuration = RibbonConfig.class)
public class ConsumerRibbonApplication {

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

}

客戶端調(diào)用實現(xiàn)

@RestController
@RequestMapping("/api")
public class ConsumerRibbonController {
    @Resource
    private RestTemplate restTemplate;

    @PostMapping("/getServerInfo")
    public String getServerInfo(){
        MultiValueMap<String, String> body = new LinkedMultiValueMap<>();
        body.add("name", "consumer8081");
        ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://EUREKA-PROVIDER/provider/api/sayHello", body, String.class);
        return responseEntity.getBody();
    }
}

測試

在這里插入圖片描述

多次請求的服務(wù)端,端口隨機變化,證明配置成功。

在這里插入圖片描述

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

相關(guān)文章

  • 詳解在Spring中如何使用AspectJ來實現(xiàn)AOP

    詳解在Spring中如何使用AspectJ來實現(xiàn)AOP

    這篇文章主要介紹了詳解在Spring中如何使用AspectJ來實現(xiàn)AOP,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • JAVA獲取rabbitmq消息總數(shù)過程詳解

    JAVA獲取rabbitmq消息總數(shù)過程詳解

    這篇文章主要介紹了JAVA獲取rabbitmq消息總數(shù)過程詳解,公司使用的是rabbitMQ,需要做監(jiān)控預警的job去監(jiān)控rabbitMQ里面的堆積消息個數(shù),如何使用rabbitMQ獲取監(jiān)控的隊列里面的隊列消息個數(shù)呢,需要的朋友可以參考下
    2019-07-07
  • 精通Java接口的使用與原理

    精通Java接口的使用與原理

    接口,在JAVA編程語言中是一個抽象類型,是抽象方法的集合,接口通常以interface來聲明。一個類通過繼承接口的方式,從而來繼承接口的抽象方法
    2022-03-03
  • spring boot和mybatis集成分頁插件

    spring boot和mybatis集成分頁插件

    這篇文章主要為大家詳細介紹了spring boot和mybatis集成分頁插件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Spring中的父子容器原理解析

    Spring中的父子容器原理解析

    這篇文章主要為大家介紹了Spring中的父子容器原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • Java 如何調(diào)用long的最大值和最小值

    Java 如何調(diào)用long的最大值和最小值

    這篇文章主要介紹了Java 如何調(diào)用long的最大值和最小值的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 基于Spring實現(xiàn)零重啟自由編排任務(wù)的定時管理器

    基于Spring實現(xiàn)零重啟自由編排任務(wù)的定時管理器

    我們發(fā)現(xiàn),我們使用Spring自帶的定時任務(wù)如果要有修改,那么就要修改代碼,然后重啟項目,所以本文就帶大家實現(xiàn)一個零重啟自由編排任務(wù)的定時管理器吧
    2023-07-07
  • java 自己實現(xiàn)DataSource實現(xiàn)實例

    java 自己實現(xiàn)DataSource實現(xiàn)實例

    這篇文章主要介紹了java 自己實現(xiàn)DataSource實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 使用RestTemplate調(diào)用RESTful?API的代碼示例

    使用RestTemplate調(diào)用RESTful?API的代碼示例

    在開發(fā)?Web?應用程序時,調(diào)用?RESTful?API?是一個常見的任務(wù),本文將介紹如何使用?RestTemplate?調(diào)用?RESTful?API,并提供示例代碼,感興趣的同學可以跟著小編一起來看看
    2023-06-06
  • 工廠方法模式_動力節(jié)點Java學院整理

    工廠方法模式_動力節(jié)點Java學院整理

    這篇文章主要介紹了工廠方法模式_動力節(jié)點Java學院整理的相關(guān)資料,需要的朋友可以參考下
    2017-08-08

最新評論