使用FeignClient設(shè)置動態(tài)Url
FeignClient設(shè)置動態(tài)Url
1. 需求描述
一般情況下,微服務(wù)內(nèi)部調(diào)用都是通過注冊中心,eureka,zookeeper,nacos等實現(xiàn)動態(tài)調(diào)用,但是對于一些外部http調(diào)用,對于不在同一微服務(wù)內(nèi),不在同一注冊中心的服務(wù)調(diào)用,可以考慮SpringCloudOpenFeign,而且可以實現(xiàn)動態(tài)URL,通過參數(shù)動態(tài)控制。
2. 實現(xiàn)方案
服務(wù)端正常springboot項目,也不一定是springboot項目,只要正常提供RESTFul接口就可以,本次測試以springboot為例。主要是客戶端調(diào)用。
1.服務(wù)端:
/**
?* (Category)控制層
?*
?* @author makejava
?* @since 2021-06-03 07:20:41
?*/
@RestController
@RequestMapping("/category")
public class CategoryController {
? ? /**
? ? ?* 服務(wù)對象
? ? ?*/
? ? @Resource
? ? private CategoryService categoryService;
? ? /**
? ? ?* 測試服務(wù)
? ? ?*/
? ? @GetMapping("/test")
? ? public Response test() {
? ? ? ? return Response.createSuccessResponse("查詢成功", "我是測試服務(wù)");
? ? }
}2.客戶端:
maven依賴
<dependency> ?? ?<groupId>org.springframework.cloud</groupId> ?? ?<artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
客戶端代碼
/**
?* 測試
?* @author zrj
?* @since 2021-07-25
?*/
@Api(value = "微盟鑒權(quán)測試")
@RestController
@RequestMapping("/weimob")
public class ActivityController {
? ? @Resource
? ? private CategoryService categoryService;
? ? @GetMapping("/test")
? ? @ApiOperation(value = "微盟獲取Code")
? ? public Response test() throws URISyntaxException {
? ? ? ? System.out.println("-----測試-----");
? ? ? ? URI uri = new URI("http://localhost:8080/category/test");
? ? ? ? Response response = categoryService.test(uri);
? ? ? ? return Response.createSuccessResponse("查詢成功", response);
? ? }
}調(diào)用接口
/**
?* 測試接口Openfeign
?* @author zrj
?* @since 2021/7/25
?**/
@Service("WeimobAuthorize")
@FeignClient(url = "http://localhost:8080/category", name = "CategoryService")
public interface CategoryService {
? ? @GetMapping
? ? Response test(URI uri);
}3. 細節(jié)分析
1.接口使用SpringMVC注解
接口方法的定義使用了SpringMVC的注解 @GetMapping、@RequestParam,其實SpringMVC的其他注解在此處都是支持的。(有其他文章提到也支持OpenFeign原有的注解@RequestLine、@Param等,但博主實測是不支持的,相關(guān)解析類為 feign.Contract,這個存疑)。
2.springcloud openfeign自動構(gòu)建實現(xiàn)類
在使用方式上,OpenFeign需要手動構(gòu)建代理對象,Spring Cloud OpenFeign 不同于 OpenFeign, Spring Cloud OpenFeign 幫我們自動生成了接口的代理對象(即實現(xiàn)類),并且注冊到Spring中,我們可以很方便的使用 @Autowired 注入代理對象然后使用。
其默認(rèn)的代理對象是 LoadBalancerFeignClient。還有一個代理對象是 feign.Client.Default。
兩者區(qū)別在于:LoadBalancerFeignClient 通過服務(wù)名(下文提到)從Eureka查找相關(guān)的節(jié)點地址url,發(fā)起調(diào)用。feign.Client.Default 僅是簡單的直接調(diào)用。
3.FeignClient屬性name與URL一定要指定
@FeignClient(url = “http://localhost:8080/category”, name = “CategoryService”)
name 屬性,是@FeignClient 注解必要的,不定義時會報錯其默認(rèn)指代Eureka上的服務(wù)名。
url 屬性,一定要指定,這是重點了! url屬性指定什么值其實不重要,因為最終都會被方法的URI參數(shù)值替換掉,它在這里另一個重要的作用,就是將接口的代理對象變成feign.Client.Default(上文提到默認(rèn)是LoadBalancerFeignClient),這樣就繞過了從Eureka取節(jié)點地址這一步,畢竟第三方的地址不可能注冊到我們的Eureka上。(相關(guān)細節(jié)可自行debug FeignClientFactoryBean.getTarget())
FeignClient注解配置url屬性實現(xiàn)指定服務(wù)方
某天,跟同學(xué)聊天,同學(xué)說起之前面試的時候面試官提的一個問題:使用spring cloud,現(xiàn)在某個服務(wù)有一個新的接口需要驗證。該接口目前只上線了一臺機器,如何指定調(diào)用方只調(diào)用這臺機器。問題大致如此,可能有些出入??偨Y(jié)起來,就是希望能夠指定訪問某臺機器。這樣的情況,在我們平時也可能經(jīng)常遇到。比如甲乙兩人需要調(diào)試新接口,但注冊中心只有一個??赡苌厦嬗斜∥旒焊磷缘姆?wù)。如果我們按照默認(rèn)的輪詢的負(fù)載均衡規(guī)則去調(diào)用,七次調(diào)用才能輪到乙的服務(wù),根本沒有辦法調(diào)試。所以這時候就需要我們能夠指定調(diào)用的服務(wù)方。
FeignClient注解通過配置url屬性可以指定調(diào)用的服務(wù)方。我們按照上面的例子,假設(shè)乙的IP為192.168.1.2,在端口8080上啟動的服務(wù),那我們就可以把我們的url配置成http://192.168.1.2:8080。這樣調(diào)用的就一直是乙的服務(wù)了。
那我們配置了url和不配置url到底產(chǎn)生了哪些不同呢?
feign,或者說open-feign底層是使用,我以為默認(rèn)是httpclient,但是我debug的結(jié)果是HttpURLConnection。知道為什么的可以留言告訴我。feign會基于配置,生成URI。當(dāng)我們不配置url的時候,URI是這樣的http://service-name/path。使用FeignClien是LoadBalancerFeignClient,該類在處理該URI的時候會對服務(wù)名進行解析,也就是從注冊中心查詢該服務(wù)名下已經(jīng)注冊的服務(wù)器信息,包括IP和端口。然后將服務(wù)名替換成真實的鏈接。而當(dāng)我們不配置url的時候,使用的FeignClient是Client的默認(rèn)實現(xiàn)Default,該類就沒有解析的這一步而是直接通過HttpURLConnection進行請求。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java分析Lambda表達式Stream流合并分組內(nèi)對象數(shù)據(jù)合并
Lambda表達式,基于Lambda所帶來的函數(shù)式編程,又引入了一個全新的Stream概念,用于解決集合類庫既有的弊端,Lambda 允許把函數(shù)作為一個方法的參數(shù)(函數(shù)作為參數(shù)傳遞進方法中)。使用 Lambda 表達式可以使代碼變的更加簡潔緊湊2022-12-12
基于Properties類操作.properties配置文件方法總結(jié)
這篇文章主要介紹了Properties類操作.properties配置文件方法總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Spring實現(xiàn)內(nèi)置監(jiān)聽器
這篇文章主要介紹了Spring 實現(xiàn)自定義監(jiān)聽器案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧,希望能給你帶來幫助2021-07-07

