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

springboot中使用Feign整合nacos,gateway進行微服務(wù)之間的調(diào)用方法

 更新時間:2023年03月29日 09:01:41   作者:jsyandxys  
這篇文章主要介紹了springboot中使用Feign整合nacos,gateway進行微服務(wù)之間的調(diào)用方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

1、什么是Feign

Feign 是 Spring Cloud Netflix 組件中的一個輕量級 RESTful 的 HTTP 服務(wù)客戶端,實現(xiàn)了負載均衡和 Rest 調(diào)用的開源框架,封裝了 Ribbon 和 RestTemplate,實現(xiàn)了 WebService 的面向接口編程,進一步降低了項目的耦合度。

Feign 內(nèi)置了 Ribbon(其主要功能是提供客戶端實現(xiàn)負載均衡算法),用來做客戶端負載均衡調(diào)用服務(wù)注冊中心的服務(wù)。

Feign 本身并不支持 Spring MVC 的注解,它有一套自己的注解,為了更方便的使用,Spring Cloud 孵化了 OpenFeign。

Feign 是一種聲明式、模板化的 HTTP 客戶端(僅在 Consumer 中使用)。

Feign 支持的注解和用法請參考官方文檔:https://github.com/OpenFeign/feign 或 spring.io 官網(wǎng)文檔

Feign 的使用方式是:使用 Feign 的注解定義接口,調(diào)用這個接口,就可以調(diào)用服務(wù)注冊中心的服務(wù)。

2、為什么使用Feign?

1.微服務(wù)之間調(diào)用變得簡單
它讓微服務(wù)之間的調(diào)用變得更簡單了,類似controller調(diào)用service

2.使用簡單
只需要創(chuàng)建一個接口,然后添加注解即可使用Feign

3.簡化代碼
Feign默認集成了Ribbon,簡化了使用Spring Cloud Ribbon負載均衡時,自動封裝服務(wù)調(diào)用客戶端的開發(fā)量

3、如何使用Feign?

目錄及項目結(jié)構(gòu)

在這里插入圖片描述

子工程

<modules>
    <module>service-provider</module>
    <module>service-provider02</module>
    <module>service-consumer</module>
    <module>service-gateway</module>
</modules>

注:
注冊中心實例 nacos
service-provider | service-provider02 服務(wù)提供者實例
service-consumer 服務(wù)消費者
service-gateway 網(wǎng)關(guān)服務(wù)

3.1注冊中心Nacos部署

部署nacos(略)

3.2部署生產(chǎn)者

1.新建maven項目,過程省略…

2.關(guān)鍵配置

server:
port: 7070 # 端口
 
spring:
application:
name: service-provider # 應(yīng)用名稱(集群下相同)
#nacos配置
spring:
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

3.邏輯部分

為了檢測Feign的負載均衡,所以在provide01中,將返回結(jié)果增加01后綴

/**
 * 查詢商品列表
 *
 * @return
 */
@Override
public List<Product> selectProductList() {
    return Arrays.asList(
            new Product(1, "華為手機01", 1, 5800D),
            new Product(2, "聯(lián)想筆記本01", 1, 6888D),
            new Product(3, "小米平板01", 5, 2020D)
    );
}

4.部署雙節(jié)點provide02

重復(fù)步驟 【1~3】,修改serverImpl邏輯,改為后綴加02

/**
 * 查詢商品列表
 *
 * @return
 */
@Override
public List<Product> selectProductList() {
    return Arrays.asList(
            new Product(1, "華為手機02", 1, 5800D),
            new Product(2, "聯(lián)想筆記本02", 1, 6888D),
            new Product(3, "小米平板02", 5, 2020D)
    );
}

5.啟動雙節(jié)點,監(jiān)控Nacos

兩個生產(chǎn)者實例已經(jīng)啟動

3.3 部署消費者,使用Feign調(diào)用provider方法

1.新建maven工程,過程省略…

2.引入nacos和feign的pom依賴

<!-- nacos  依賴 -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    <version>0.9.0.RELEASE</version>
</dependency><!-- spring cloud openfeign 依賴 -->
<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

3.添加配置文件

server:
port: 9090 # 端口
 
spring:
application:
name: service-consumer # 應(yīng)用名稱
spring:
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

4.在服務(wù)接口層聲明使用Feign

使用FeignClient注解,聲明要調(diào)用的服務(wù)

// 聲明需要調(diào)用的服務(wù)
@FeignClient("service-provider")
public interface ProductService

對方法使用GetMapping注解,配置需要調(diào)用的服務(wù)路由地址

// 配置需要調(diào)用的服務(wù)地址及參數(shù)
@GetMapping("/product/list")
List<Product> selectProductList();

5.方法調(diào)用

在另一個impl里調(diào)用ProductService的方法,而不用關(guān)注ProductServiceImpl里面的實現(xiàn)邏輯,它會遠程請求生產(chǎn)者中controller里的方法.

在這里插入圖片描述

/**
   * 根據(jù)主鍵查詢訂單
   *
   * @param id
   * @return
   */
  @Override
  public Order selectOrderById(Integer id) {
      return new Order(id, "order-001", "中國", 22788D,
              productService.selectProductList());
  }

消費者controller中的方法

在這里插入圖片描述

/**
 * 根據(jù)主鍵查詢訂單
 *
 * @param id
 * @return
 */
@GetMapping("/{id}")
public Order selectOrderById(@PathVariable("id") Integer id) {
    return orderService.selectOrderById(id);
}

過postman調(diào)用 localhost:9090/order/2 結(jié)果,可以看到已經(jīng)成功使用Feign進行了遠程調(diào)用,

并且同一個請求,返回兩個provider的不同結(jié)果,由此可知Feign也實現(xiàn)了負載均衡

調(diào)用1

調(diào)用2

4.ribbon負載均衡策略

在消費者配置文件中修改ribbon的負載均衡策略

在這里插入圖片描述

service-provider:
ribbon:
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #配置規(guī)則 隨機
# NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RoundRobinRule #配置規(guī)則 輪詢
# NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RetryRule #配置規(guī)則 重試
# NFLoadBalancerRuleClassName: com.netflix.loadbalancer.WeightedResponseTimeRule #配置規(guī)則 響應(yīng)時間權(quán)重
# NFLoadBalancerRuleClassName: com.netflix.loadbalancer.BestAvailableRule #配置規(guī)則 最空閑連接策略

5.Feign傳參

1.Get方法

使用 @PathVariable 注解或 @RequestParam 注解接收請求參數(shù)

provider接口層ProductService.java
ProductService.java方法

/**
 * 根據(jù)主鍵查詢商品
 *
 * @param id
 * @return
 */
Product selectProductById(Integer id);
provider實現(xiàn)類ProductServiceImpl.java

ProductServiceImpl.java方法

/**
 * 根據(jù)主鍵查詢商品
 *
 * @param id
 * @return
 */
@Override
public Product selectProductById(Integer id) {
    return new Product(id, "冰箱", 1, 2666D);
}

provider的控制類ProductController.java

ProductController.java方法

/**
 * 根據(jù)主鍵查詢商品
 *
 * @param id
 * @return
 */
@GetMapping("/{id}")
public Product selectProductById(@PathVariable("id") Integer id) {
    return productService.selectProductById(id);
}

provider服務(wù)中,controller使用了(@PathVariable(“id”) Integer id) 進行參數(shù)接收

consumer的接口層ProductService.java

@GetMapping("/product/{id}")
Product selectProductById(@PathVariable("id") Integer id);

consumer服務(wù)中,使用了(@PathVariable(“id”) Integer id) 進行參數(shù)接收,寫法類似于在controller中定義請求方法和定義參數(shù)

consumer的接口層OrderService.java

Order getOrderById(Integer id);

consumer的接口實現(xiàn)類OrderServiceImpl.java

@Override
public Order getOrderById(Integer id) {
    return new Order(id, "order-003", "中國", 2666D,
            Arrays.asList(productService.selectProductById(id)));
}

consumer的控制類OrderController.java

@GetMapping("selectProductById/{id}")
public Order selectProductById(@PathVariable("id") Integer id) {
    return orderService.getOrderById(id);
}

訪問localhost:9090/order/selectProductById/888得到結(jié)果

在這里插入圖片描述

Post方法
使用 @RequestBody 注解接收請求參數(shù)。

provider的ProductService.java

/**
 * 新增商品
 *
 * @param product
 * @return
 */
Map<Object, Object> createProduct(Product product);

provider的ProductServiceImpl.java

/**
   * 新增商品
   *
   * @param product
   * @return
   */
  @Override
  public Map<Object, Object> createProduct(Product product) {
      System.out.println(product.getProductName());
      return new HashMap<Object, Object>() {{
          put("code", 200);
          put("message", "新增成功");
      }};
  }

provider的ProductController.java

/**
  * 新增商品
  *
  * @param product
  * @return
  */
 @PostMapping("/save")
 public Map<Object, Object> createProduct(@RequestBody Product product) {
     return productService.createProduct(product);
 }

consumer的ProductService.java

/**
 * 新增商品
 *
 * @param product
 * @return
 */
@PostMapping("/product/save")
Map<Object, Object> createProduct(Product product);
consumer的OrderService.java

Map<Object, Object> createProduct(Product product);
consumer的OrderServiceImpl.java

@Override
public Map<Object, Object> createProduct(Product product) {
    return productService.createProduct(product);
}

consumer的OrderController.java

/**
  * 新增商品
  *
  * @param product
  * @return
  */
 @PostMapping("/save")
 public Map<Object, Object> createProduct(Product product) {
     return orderService.createProduct(product);
 }

訪問http://localhost:9090/order/save 參數(shù)

id:6
productName:華為
productNum:1
productPrice:6666666

執(zhí)行結(jié)果

在這里插入圖片描述

在這里插入圖片描述

6.Feign 性能優(yōu)化

1.Gzip 壓縮
gzip 是一種數(shù)據(jù)格式,采用 deflate 算法壓縮數(shù)據(jù);gzip 是一種流行的文件壓縮算法,應(yīng)用十分廣泛,尤其是在 Linux 平臺。

2.gzip 能力
當 Gzip 壓縮一個純文本文件時,效果是非常明顯的,大約可以減少 70% 以上的文件大小。

3.gzip 作用
網(wǎng)絡(luò)數(shù)據(jù)經(jīng)過壓縮后實際上降低了網(wǎng)絡(luò)傳輸?shù)淖止?jié)數(shù),最明顯的好處就是可以加快網(wǎng)頁加載的速度。網(wǎng)頁加載速度加快的好處不言而喻,除了節(jié)省流量,改善用戶的瀏覽體驗外,另一個潛在的好處是 Gzip 與搜索引擎的抓取工具有著更好的關(guān)系。例如 Google 就可以通過直接讀取 gzip 文件來比普通手工抓取更快地檢索網(wǎng)頁。

4.配置HTTP 連接池
4.1HTTP背景
兩臺服務(wù)器建立 HTTP 連接的過程是很復(fù)雜的一個過程,涉及到多個數(shù)據(jù)包的交換,很耗時間。
HTTP 連接需要的 3 次握手 4 次揮手開銷很大,這一開銷對于大量的比較小的 HTTP 消息來說更大。
4.2解決方案
采用 HTTP 連接池,可以節(jié)約大量的 3 次握手 4 次揮手,這樣能大大提升吞吐量。

Feign 的 HTTP 客戶端支持 3 種框架:HttpURLConnection、HttpClient、OkHttp;默認是 HttpURLConnection??梢酝ㄟ^查看源碼 org.springframework.cloud.openfeign.ribbon.FeignRibbonClientAutoConfiguration.java 得知。

傳統(tǒng)的 HttpURLConnection 是 JDK 自帶的,并不支持連接池,如果要實現(xiàn)連接池的機制,還需要自己來管理連接對象。對于網(wǎng)絡(luò)請求這種底層相對復(fù)雜的操作,如果有可用的其他方案,沒有必要自己去管理連接對象。
HttpClient 相比傳統(tǒng) JDK 自帶的 HttpURLConnection,它封裝了訪問 HTTP 的請求頭,參數(shù),內(nèi)容體,響應(yīng)等等;它不僅使客戶端發(fā)送 HTTP 請求變得容易,而且也方便了開發(fā)人員測試接口(基于 HTTP 協(xié)議的),既提高了開發(fā)的效率,又提高了代碼的健壯性;另外高并發(fā)大量的請求網(wǎng)絡(luò)的時候,也是用“連接池”提升吞吐量。
添加依賴

<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
    <version>10.7.4</version>
</dependency>

配置開啟連接池

feign:
  httpclient:
    enabled: true # 開啟 httpclient

使用壓測工具檢測單線程 10000次請求網(wǎng)絡(luò)響應(yīng)情況

圖1.未配置httpclient連接池.新建連接和關(guān)閉連接占用大量時間,端口被占用無法釋放.導(dǎo)致后來的連接無法被創(chuàng)建,增加程序異常幾率

在這里插入圖片描述

圖2.配置httpClient連接池開啟,第一次交互會打開連接,交互結(jié)束后連接并不關(guān)閉,下次交互就省去了建立連接的過程

在這里插入圖片描述

7.整合gateway網(wǎng)關(guān)服務(wù)

1.搭建gateway網(wǎng)關(guān)服務(wù)(略)
2.增加配置

server:
  port: 8001  #網(wǎng)關(guān)端口
spring:
  application:
    name: nacos-gateway
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848  #注冊中心地址
      config:
        server-addr: localhost:8848  #配置中心地址 TODO配置中心讀取不到 需要調(diào)查原因
        file-extension: yaml
    gateway:
      discovery:
        locator:
          enabled: true
          lower-case-service-id: true
      routes:
        - id: nacos-gateway-provider
          uri: lb://service-consumer  #目標服務(wù)地址
          predicates: #斷言
            - Path=/**

3.測試8001端口轉(zhuǎn)發(fā)是否正常

在這里插入圖片描述

到此這篇關(guān)于springboot中使用Feign整合nacos,gateway進行微服務(wù)之間的調(diào)用方法的文章就介紹到這了,更多相關(guān)springboot Feign微服務(wù)調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決使用IDEA時跳轉(zhuǎn)到.class的問題

    解決使用IDEA時跳轉(zhuǎn)到.class的問題

    這篇文章主要介紹了解決使用IDEA時跳轉(zhuǎn)到.class的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • springboot整合mongodb使用詳解

    springboot整合mongodb使用詳解

    MongoDB是一個文檔數(shù)據(jù)庫(以?JSON?為數(shù)據(jù)模型),由C++語言編寫,旨在為WEB應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案,本文就給大家介紹一下詳細介紹一下springboot整合mongodb使用,需要的朋友可以參考下
    2023-07-07
  • SpringBoot自定義Starter實現(xiàn)流程詳解

    SpringBoot自定義Starter實現(xiàn)流程詳解

    SpringBoot中的starter是一種非常重要的機制,能夠拋棄以前繁雜的配置,將其統(tǒng)一集成進starter,應(yīng)用者只需要在maven中引入starter依賴,SpringBoot就能自動掃描到要加載的信息并啟動相應(yīng)的默認配置。starter讓我們擺脫了各種依賴庫的處理,需要配置各種信息的困擾
    2022-09-09
  • elasticsearch 8.2.3 安裝及springboot簡單使用

    elasticsearch 8.2.3 安裝及springboot簡單使用

    這篇文章主要介紹了elasticsearch 8.2.3 安裝及springboot簡單使用,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • SpringBoot枚舉類型參數(shù)認證的實現(xiàn)代碼

    SpringBoot枚舉類型參數(shù)認證的實現(xiàn)代碼

    項目當中經(jīng)常需要接口參數(shù)是否在一個可選的范圍內(nèi),也就是驗證類枚舉參數(shù)的需求,所以本文我們將使用SpringBoot實現(xiàn)枚舉類型參數(shù)認證,文中有詳細的代碼示例,需要的朋友可以參考下
    2023-12-12
  • Java使用建造者模式實現(xiàn)辦理手機套餐功能詳解

    Java使用建造者模式實現(xiàn)辦理手機套餐功能詳解

    這篇文章主要介紹了Java使用建造者模式實現(xiàn)辦理手機套餐功能,較為詳細的描述了建造者模式的概念、原理并結(jié)合實例形式分析了Java使用建造者模式實現(xiàn)的辦理手機套餐功能具體步驟與相關(guān)操作注意事項,需要的朋友可以參考下
    2018-05-05
  • Web三大組件之Filter,Listener和Servlet詳解

    Web三大組件之Filter,Listener和Servlet詳解

    這篇文章主要為大家詳細介紹了Web三大組件之Filter,Listener和Servlet,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • solr 配置中文分析器/定義業(yè)務(wù)域/配置DataImport功能方法(測試用)

    solr 配置中文分析器/定義業(yè)務(wù)域/配置DataImport功能方法(測試用)

    下面小編就為大家?guī)硪黄猻olr 配置中文分析器/定義業(yè)務(wù)域/配置DataImport功能方法(測試用)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 基于Spring中的線程池和定時任務(wù)功能解析

    基于Spring中的線程池和定時任務(wù)功能解析

    下面小編就為大家?guī)硪黄赟pring中的線程池和定時任務(wù)功能解析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • SpringBoot使用@Scheduled實現(xiàn)定時任務(wù)的并行執(zhí)行

    SpringBoot使用@Scheduled實現(xiàn)定時任務(wù)的并行執(zhí)行

    在SpringBoot中,如果使用@Scheduled注解來定義多個定時任務(wù),默認情況下這些任務(wù)將會被安排在一個單線程的調(diào)度器中執(zhí)行,這意味著,這些任務(wù)將會串行執(zhí)行,而不是并行執(zhí)行,本文介紹了SpringBoot使用@Scheduled實現(xiàn)定時任務(wù)的并行執(zhí)行,需要的朋友可以參考下
    2024-06-06

最新評論