您好,登錄后才能下訂單哦!
今天小編給大家分享一下SpringCloud基于Feign的可編程式接口怎么調(diào)用的相關知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
Feign 可以替代 RestTemplate 完成可編程式接口調(diào)用,并且內(nèi)部集成 Ribbon 實現(xiàn)了負載均衡
pom文件增加 openfeign 依賴
<!-- feign --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
啟動類上增加 @EnableFeignClients 注解
@EnableFeignClients @SpringBootApplication public class OrderApplication { public static void main(String[] args) { SpringApplication.run(OrderApplication.class, args); } }
創(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)用的微服務里的controller類復制一份過來,修修改改就行了
ps:
1.@FeignClient(“bookschina-service”):訪問 spring.application.name=bookschina-service 的微服務
2.@RequestMapping、@GetMapping、@PathVariable 用來映射地址,和controller中的用法一樣
3.上面這個接口對應的就是 bookschina-service 微服務下映射地址為 /bookschina/spiderBookList/{searchkey}/{pageno} 的controller類方法
測試類如下
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()); } }
application 文件中加入配置
feign: client: config: default: # default 全局配置,局部配置的話可以換成請求的服務名稱 loggerLevel: NONE # 日志級別 NONE BASIC HEADERS FULL
ps:
1.NONE:沒有日志
2.BASIC:記錄http請求發(fā)送目標、發(fā)送時間、返回時間、總耗時等信息
3.HEADERS:在 BASIC 基礎上記錄 請求頭 和 響應頭 信息
4.FULL:在 BASIC 和 HEADERS 的基礎上記錄 請求體 和 響應體 信息
5.上線后為了優(yōu)化性能 日志級別盡量用 NONE 或者 BASIC
Feign底層客戶端默認實現(xiàn)是 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 # 最大連接數(shù) max-connections-per-route: 50 # 每個請求接口的最大連接數(shù)
ps:
max-connections 和 max-connections-per-route 的值需要根據(jù)具體情況設定
以上就是“SpringCloud基于Feign的可編程式接口怎么調(diào)用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。