成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

SpringCloud中Ribbon和Feign組件如何使用-創(chuàng)新互聯(lián)

SpringCloud中Ribbon和Feign組件如何使用,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

創(chuàng)新互聯(lián)建站是一家專業(yè)提供古浪企業(yè)網(wǎng)站建設,專注與成都網(wǎng)站制作、成都做網(wǎng)站、H5響應式網(wǎng)站、小程序制作等業(yè)務。10年已為古浪眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。

一、Ribbon簡介

1、基本概念

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

2、負載均衡簡介

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

1)集中式

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

2)進程內(nèi)

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

3、Ribbon負載策略

SpringCloud中Ribbon和Feign組件如何使用

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

二、Feign簡介

1、基本概念

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

2、執(zhí)行流程

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

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

3) RequestTemplate 生成 Request請求,結(jié)合Ribbon實現(xiàn)服務調(diào)用負載均衡策略。

三、綜合使用案例

1、項目結(jié)構圖

SpringCloud中Ribbon和Feign組件如何使用

1)、模塊描述

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

2)、依賴Eureka知識

上篇文章Eureka使用:

2、Ribbon服務調(diào)用

代碼所屬模塊: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() ;
        // 重試算法:默認情況,訪問某個服務連續(xù)三次失敗,就不會再訪問
        // return new RetryRule() ;
        // 隨機算法
        return new RandomRule() ;
    }
}

3)、調(diào)用方式

@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正基于此,實現(xiàn)多個服務調(diào)用的負載均衡。

spring:
  application:
    name: node02-provider

4)、提供方接口

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

3、Feign服務調(diào)用

代碼所屬模塊: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)、調(diào)用方式

@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 ;
}

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)-成都網(wǎng)站建設公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。

文章題目:SpringCloud中Ribbon和Feign組件如何使用-創(chuàng)新互聯(lián)
網(wǎng)站網(wǎng)址:http://jinyejixie.com/article18/cceidp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、企業(yè)建站、網(wǎng)站改版ChatGPT、響應式網(wǎng)站、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
永靖县| 长宁县| 治县。| 马鞍山市| 华坪县| 娄烦县| 耿马| 房山区| 会宁县| 盘锦市| 曲水县| 曲阜市| 怀安县| 建宁县| 安多县| 巴彦县| 儋州市| 嵊州市| 内江市| 崇文区| 汪清县| 上饶市| 荣昌县| 申扎县| 尚义县| 巴彦淖尔市| 贡觉县| 文水县| 舒兰市| 汤原县| 枣阳市| 嘉鱼县| 郓城县| 云阳县| 寿光市| 萝北县| 平泉县| 石河子市| 井陉县| 峨山| 防城港市|