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

溫馨提示×

溫馨提示×

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

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

Ribbon和Feign組件簡介及實現服務調用的負載均衡流程介紹

發布時間:2020-04-20 16:28:15 來源:億速云 閱讀:676 作者:三月 欄目:編程語言

下文給大家帶來Ribbon和Feign組件簡介及實現服務調用的負載均衡流程介紹,希望能夠給大家在實際運用中帶來一定的幫助,負載均衡涉及的東西比較多,理論也不多,網上有很多書籍,今天我們就用億速云在行業內累計的經驗做一個解答。

本文源碼:GitHub·點這里 ||  GitEE·點這里

一、Ribbon簡介

1、基本概念

Ribbon是一個客戶端的負載均衡(Load Balancer,簡稱LB)器,它提供對大量的HTTP和TCP客戶端的訪問控制。

2、負載均衡簡介

目前主流的負載均衡方案可分成兩類:

1)集中式

即在服務的消費方和提供方之間使用獨立的LB設施,可以是硬件,如F5,也可以是軟件,如nginx,由該設施負責把訪問請求通過某種策略轉發至服務的提供方;

2)進程內

將LB邏輯集成到消費方,消費方從服務注冊中心獲取可用服務列表,然后根據指定負載均衡策略選擇合適的云服務器。Ribbon就屬于該方式。

3、Ribbon負載策略

Ribbon和Feign組件簡介及實現服務調用的負載均衡流程介紹

1) RoundRobinRule 輪詢
輪詢服務列表List<Server>的index,選擇index對應位置的服務。
2) RandomRule 隨機
隨機服務列表List<Server>的index,選擇index對應位置的服務。
3) RetryRule 重試
指定時間內,重試(請求)某個服務不成功達到指定次數,則不再請求該服務。

二、Feign簡介

1、基本概念

Feign 是一個聲明式的 Web Service 客戶端。它的出現使開發 Web Service 客戶端變得很簡單。使用 Feign 只需要創建一個接口加上對應的注解,比如:@FeignClient 接口類注解。

2、執行流程

1) 主程序入口添加 @EnableFeignClients 注解開啟對 FeignClient 接口掃描加載。接口使用@FeignClient注解。

2) 調用Feign 接口中的方法被時,通過JDK的代理的方式,生成具體的 RequestTemplate。

3) RequestTemplate 生成 Request請求,結合Ribbon實現服務調用負載均衡策略。

三、綜合使用案例

1、項目結構圖

Ribbon和Feign組件簡介及實現服務調用的負載均衡流程介紹

1)、模塊描述

Eureka注冊中心
node02-eureka-7001
兩個服務提供方
node02-provider-6001
node02-provider-6002
Ribbon服務調用
node02-consume-8001
Feign服務調用
node02-consume-8002

2)、依賴Eureka知識

上篇文章Eureka使用:

2、Ribbon服務調用

代碼所屬模塊:node02-consume-8001

1)、核心依賴

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

2)、配置文件

@Configuration
public class LoadConfig {
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate (){
        return new RestTemplate() ;
    }
    @Bean
    public IRule getIRule (){
        // 默認輪詢算法
        // return new RoundRobinRule() ;
        // 重試算法:默認情況,訪問某個服務連續三次失敗,就不會再訪問
        // return new RetryRule() ;
        // 隨機算法
        return new RandomRule() ;
    }
}

3)、調用方式

@RestController
public class ConsumeController {

    @Autowired
    private RestTemplate restTemplate ;

    String server_name = "http://NODE02-PROVIDER" ;
    // http://localhost:8001/showInfo
    @RequestMapping("/showInfo")
    public String showInfo (){
        return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
    }

}

這里的NODE02-PROVIDER就是服務提供方的配置文件。兩個服務提供方的這塊配置相同,Ribbon正基于此,實現多個服務調用的負載均衡。

spring:
  application:
    name: node02-provider

4)、提供方接口

@RequestMapping("/getInfo")
public String getInfo (){
    LOG.info("provider-6002");
    return "success" ;
}

3、Feign服務調用

代碼所屬模塊:node02-consume-8002

1)、核心依賴

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

2)、配置文件

@FeignClient(value = "NODE02-PROVIDER")
public interface GetAuthorService {
    @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET)
    String getAuthorInfo (@PathVariable("authorId") String authorId) ;
}

3)、調用方式

@RestController
public class ConsumeController {
    @Resource
    private GetAuthorService getAuthorService ;
    @RequestMapping(value = "/getAuthorInfo")
    public String getAuthorInfo () {
        return getAuthorService.getAuthorInfo("1") ;
    }
}

4)、啟動類注解

// 因為包名路徑不同,需要加basePackages屬性
@EnableFeignClients(basePackages={"cloud.block.code.service"})

5)、提供方接口

@RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET)
public String getAuthorInfo (@PathVariable("authorId") String authorId) {
    LOG.info("provider-6002");
    return "知了一笑"+authorId ;
}

四、源代碼說明

GitHub·地址
https://github.com/cicadasmile/spring-cloud-base
GitEE·地址
https://gitee.com/cicadasmile/spring-cloud-base

看了以上關于Ribbon和Feign組件簡介及實現服務調用的負載均衡流程介紹,如果大家還有什么地方需要了解的可以在億速云行業資訊里查找自己感興趣的或者找我們的專業技術工程師解答的,億速云技術工程師在行業內擁有十幾年的經驗了。

 

向AI問一下細節

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

AI

巍山| 唐河县| 云阳县| 兴安县| 乐昌市| 柳江县| 宝清县| 剑河县| 三门峡市| 澄迈县| 永靖县| 孟津县| 托里县| 田阳县| 永寿县| 应用必备| 通山县| 囊谦县| 特克斯县| 饶河县| 九江市| 巫山县| 兖州市| 吐鲁番市| 阜康市| 晋宁县| 班戈县| 洛扎县| 宁乡县| 嘉兴市| 镇沅| 红原县| 枣阳市| 嵊泗县| 积石山| 邓州市| 张家口市| 石河子市| 陆丰市| 平泉县| 台前县|