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.加注解
啟動(dòng)類上增加 @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.上面這個(gè)接口對應(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ā)送時(shí)間、返回時(shí)間、總耗時(shí)等信息
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請求都要三次握手,斷開時(shí)四次揮手,有點(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 # 每個(gè)請求接口的最大連接數(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 輸入一個(gè)數(shù)字組成的數(shù)組(輸出該數(shù)組的最大值和最小值)
這篇文章主要介紹了java 輸入一個(gè)數(shù)字組成的數(shù)組,輸出該數(shù)組的最大值和最小值,需要的朋友可以參考下2017-02-02使用kotlin集成springboot開發(fā)的超詳細(xì)教程
目前大多數(shù)都在使用java集成 springboot進(jìn)行開發(fā),本文演示僅僅將 java換成 kotlin,其他不變的情況下進(jìn)行開發(fā),需要的朋友可以參考下2021-09-09spring整合shiro框架的實(shí)現(xiàn)步驟記錄
Shiro是一個(gè)強(qiáng)大易用的Java安全框架,提供了認(rèn)證、授權(quán)、加密和會(huì)話管理等功能。下面這篇文章主要給大家介紹了關(guān)于spring整合shiro框架的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-05-05java web驗(yàn)證碼實(shí)現(xiàn)代碼分享
這篇文章主要為大家分享了java web驗(yàn)證碼的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問題
這篇文章主要介紹了詳解SpringMVC中設(shè)置靜態(tài)資源不被攔截的問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02Spring Boot 實(shí)例代碼之通過接口安全退出
這篇文章主要介紹了Spring Boot 實(shí)例代碼之通過接口安全退出的相關(guān)資料,需要的朋友可以參考下2017-09-09