SpringCloud基于Feign的可編程式接口調(diào)用實(shí)現(xiàn)
前言
Feign 可以替代 RestTemplate 完成可編程式接口調(diào)用,并且內(nèi)部集成 Ribbon 實(shí)現(xiàn)了負(fù)載均衡

一、基本使用
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.聲明接口
創(chuàng)建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
);
}
直接把你需要調(diào)用的微服務(wù)里的controller類復(fù)制一份過來,修修改改就行了
ps:
1.@FeignClient(“bookschina-service”):訪問 spring.application.name=bookschina-service 的微服務(wù)
2.@RequestMapping、@GetMapping、@PathVariable 用來映射地址,和controller中的用法一樣
3.上面這個接口對應(yīng)的就是 bookschina-service 微服務(wù)下映射地址為 /bookschina/spiderBookList/{searchkey}/{pageno} 的controller類方法

4.調(diào)用
測試類如下
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() {
// 參數(shù)
String searchKey = "東野圭吾";
Integer pageNo = 1;
// 調(diào)用
JSONObject booksJB = bookschinaClient.searchBookschina(searchKey, pageNo);
log.info(booksJB.toString());
}
}
二、進(jìn)階
1.日志配置
application 文件中加入配置
feign:
client:
config:
default: # default 全局配置,局部配置的話可以換成請求的服務(wù)名稱
loggerLevel: NONE # 日志級別 NONE BASIC HEADERS FULL
ps:
1.NONE:沒有日志
2.BASIC:記錄http請求發(fā)送目標(biāo)、發(fā)送時間、返回時間、總耗時等信息
3.HEADERS:在 BASIC 基礎(chǔ)上記錄 請求頭 和 響應(yīng)頭 信息
4.FULL:在 BASIC 和 HEADERS 的基礎(chǔ)上記錄 請求體 和 響應(yīng)體 信息
5.上線后為了優(yōu)化性能 日志級別盡量用 NONE 或者 BASIC
2.性能優(yōu)化
Feign底層客戶端默認(rèn)實(shí)現(xiàn)是 URLConnection,不支持連接池,每次http請求都要三次握手,斷開時四次揮手,有點(diǎn)浪費(fèi)性能,可以用 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 # 最大連接數(shù)
max-connections-per-route: 50 # 每個請求接口的最大連接數(shù)
ps:
1.max-connections 和 max-connections-per-route 的值需要根據(jù)具體情況設(shè)定
到此這篇關(guān)于SpringCloud基于Feign的可編程式接口調(diào)用實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringCloud Feign可編程式接口調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 輸入一個數(shù)字組成的數(shù)組(輸出該數(shù)組的最大值和最小值)
這篇文章主要介紹了java 輸入一個數(shù)字組成的數(shù)組,輸出該數(shù)組的最大值和最小值,需要的朋友可以參考下2017-02-02
使用kotlin集成springboot開發(fā)的超詳細(xì)教程
目前大多數(shù)都在使用java集成 springboot進(jìn)行開發(fā),本文演示僅僅將 java換成 kotlin,其他不變的情況下進(jìn)行開發(fā),需要的朋友可以參考下2021-09-09
spring整合shiro框架的實(shí)現(xiàn)步驟記錄
Shiro是一個強(qiáng)大易用的Java安全框架,提供了認(rèn)證、授權(quán)、加密和會話管理等功能。下面這篇文章主要給大家介紹了關(guān)于spring整合shiro框架的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-05-05
java web驗(yàn)證碼實(shí)現(xiàn)代碼分享
這篇文章主要為大家分享了java web驗(yàn)證碼的實(shí)現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06
詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問題
這篇文章主要介紹了詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
Spring Boot 實(shí)例代碼之通過接口安全退出
這篇文章主要介紹了Spring Boot 實(shí)例代碼之通過接口安全退出的相關(guān)資料,需要的朋友可以參考下2017-09-09

