首頁 > 軟體

SpringCloud基於Feign的可程式化式介面呼叫實現

2022-04-18 16:00:46

前言

Feign 可以替代 RestTemplate 完成可程式化式介面呼叫,並且內部整合 Ribbon 實現了負載均衡

一、基本使用

1.引依賴

pom檔案增加 openfeign 依賴

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

2.加註解

啟動類上增加 @EnableFeignClients 註解

@EnableFeignClients
@SpringBootApplication
public class OrderApplication {

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

3.宣告介面

建立client包,包下放使用到的介面

package com.cxstar.client;

import com.alibaba.fastjson.JSONObject;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

@FeignClient("bookschina-service")
@RequestMapping("/bookschina")
public interface BookschinaClient {

    @GetMapping("/spiderBookList/{searchkey}/{pageno}")
    JSONObject searchBookschina(
            @PathVariable("searchkey") String searchKey,
            @PathVariable("pageno") Integer pageNo
    );

}

直接把你需要呼叫的微服務裡的controller類複製一份過來,修修改改就行了
ps:
1.@FeignClient(“bookschina-service”):存取 spring.application.name=bookschina-service 的微服務
2.@RequestMapping、@GetMapping、@PathVariable 用來對映地址,和controller中的用法一樣
3.上面這個介面對應的就是 bookschina-service 微服務下對映地址為 /bookschina/spiderBookList/{searchkey}/{pageno} 的controller類方法

4.呼叫

測試類如下

package com.cxstar;

import com.alibaba.fastjson.JSONObject;
import com.cxstar.client.BookschinaClient;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;


@Slf4j
@SpringBootTest
class OrderApplicationTests {

    @Autowired
    private BookschinaClient bookschinaClient;

    void booksChinaTest() {
    
		// 引數
        String searchKey = "東野圭吾";
        Integer pageNo = 1;
		// 呼叫
        JSONObject booksJB = bookschinaClient.searchBookschina(searchKey, pageNo);
        log.info(booksJB.toString());

    }

}

二、進階

1.紀錄檔設定

application 檔案中加入設定

feign:
  client:
    config:
      default:                      # default 全域性設定,區域性設定的話可以換成請求的服務名稱
        loggerLevel: NONE			# 紀錄檔級別 NONE BASIC HEADERS FULL

ps:
1.NONE:沒有紀錄檔
2.BASIC:記錄http請求傳送目標、傳送時間、返回時間、總耗時等資訊
3.HEADERS:在 BASIC 基礎上記錄 請求頭 和 響應頭 資訊
4.FULL:在 BASIC 和 HEADERS 的基礎上記錄 請求體 和 響應體 資訊
5.上線後為了優化效能 紀錄檔級別儘量用 NONE 或者 BASIC

2.效能優化

Feign底層使用者端預設實現是 URLConnection,不支援連線池,每次http請求都要三次握手,斷開時四次揮手,有點浪費效能,可以用 Apache HttpClient 替代 URLConnection

<1>pom 引入依賴

<!-- feign 連線池 -->
<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
</dependency>

<2>application 檔案中加入設定

feign:
  httpclient:
    enabled: true                   # 開啟feign對 httpclient 的支援
    max-connections: 200            # 最大連線數
    max-connections-per-route: 50   # 每個請求介面的最大連線數

ps:
1.max-connections 和 max-connections-per-route 的值需要根據具體情況設定

到此這篇關於SpringCloud基於Feign的可程式化式介面呼叫實現的文章就介紹到這了,更多相關SpringCloud Feign可程式化式介面呼叫內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com