springboot2.x引入feign踩的坑及解決
springboot2.x引入feign踩的坑
一、需求
最近公司項目需求,需要調(diào)用第三方服務(wù)的接口,所以選用了feign來實現(xiàn)(這里只說springboot2.x的pom引用,沒有怎么使用,網(wǎng)上一大頓)。
二、什么是feign
feign是聲明式的web service客戶端,它讓微服務(wù)之間的調(diào)用變得更簡單了,類似controller調(diào)用service。Spring Cloud集成了Ribbon和Eureka,可在使用Feign時提供負(fù)載均衡的http客戶端。
三、springboot1.x中feign的使用
這里不展示hystrix熔斷的配置和實現(xiàn)
3.1 在pom.xml中加入依賴
<!-- feign依賴 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> <version>1.2.2.RELEASE</version> </dependency> <!-- hystrix 斷路器依賴 用于處理請求第三方接口超時 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> <version>1.2.3.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId> <version>1.2.3.RELEASE</version> </dependency>
3.2 在啟動類上添加注解@EnableFeignClients
@EnableCaching @EnableAutoConfiguration @SpringBootApplication @EnableConfigurationProperties @ServletComponentScan//配置druid必須加的注解,如果不加,訪問頁面打不開,filter和servlet、listener之類的需要單獨進(jìn)行注冊才能使用,spring boot里面提供了該注解起到注冊作用 @EnableTransactionManagement @EnableFeignClients @EnableHystrix @EnableCircuitBreaker @EnableHystrixDashboard public class App { public static void main(String[] args) { SpringApplication.run(App.class, args); } }
3.3 啟動springboot的啟動類
四、springboot2.x中feign的使用
這里不展示hystrix熔斷的配置和實現(xiàn)
在另外項目中引用的時候用的是spring2.x,所以就出現(xiàn)問題了,引入feign失敗。網(wǎng)上說springboot2.x需要如下引入:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
但是我使用openfeign在啟動的時候報錯:
所以我將pom.xml的依賴改成了這樣(<parent>一定要注釋掉):
<!-- 此處一定要注釋掉parent繼承父級的依賴 --> <!--<parent>--> <!--<groupId>org.springframework.boot</groupId>--> <!--<artifactId>spring-boot-starter-parent</artifactId>--> <!--<version>2.1.2.RELEASE</version>--> <!--</parent>--> <dependencies> <!-- ...其他的依賴省略了 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> <version>1.2.3.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId> <version>1.2.3.RELEASE</version> </dependency> </dependencies> <repositories> <repository> <id>spring-milestones</id> <name>Spring Milestones</name> <url>https://repo.spring.io/libs-milestone</url> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-openfeign</artifactId> <version>2.0.0.RC1</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
啟動類注解和springboot1.x中的一樣,啟動工程,就可以了。
feign調(diào)用方式比較
一、事發(fā)原因
兩個東家都使用SpringCloud,巴拉巴拉用上了Spring全家桶,從eureka到ribbon,從ribbon到feign,從feign到hystrix,然后在使用feign的時候發(fā)現(xiàn)使用方式不同,仔細(xì)一看這種調(diào)用方式,唉,麻煩,我怎么要自己定義DTO,自己定義Fallback, 自己定義方法呢?用上之后,其實發(fā)現(xiàn)各有各的好處,今天就來一一記錄一下。
二、方式1介紹
我們在開發(fā)服務(wù)的時候,會把接口和實現(xiàn)分開, 即有一個API模塊和一個Service模塊,消費者依賴API的jar包,直接注入API中的Service,則可以直接通過Feign調(diào)用到對應(yīng)的服務(wù),對應(yīng)的項目結(jié)構(gòu)如下:
我們在接口API中定義好方法,并加上Feign注解等(MICRO-PROVIDER2是服務(wù)名,注冊到Eureka Server上的名稱。 使用Feign還可以自己實現(xiàn)fallback,設(shè)置超時默認(rèn)放回值。這里做測試,不寫過多代碼)。
具體的實現(xiàn)如下圖所示。
接下來就是我們?nèi)绾卧赾onsumer中去消費這個服務(wù)了,我們會在service服務(wù)中,依賴api的jar包,實現(xiàn)Provider2Service即可。
具體的實現(xiàn)如下圖
代碼中的實現(xiàn)邏輯:
三、方式2介紹
這中方式介紹起來比較簡單。直接在消費者中定義新的service接口,通過Feign注解,定義方法,調(diào)用的url和被調(diào)用服務(wù)的url相同,實現(xiàn)邏輯如下。
四、調(diào)用結(jié)果測試
方式2:
方式1:
可以看到,兩種方式都是可以消費到服務(wù)(本質(zhì)是一樣)。但是兩種方式各有好處和壞處,我們要來比較下,看看究竟哪一種才是我們需要的呢?
五、兩種方式對比
通過兩種方式的對比,我們可以看到的優(yōu)優(yōu)劣勢主要有:
方式一:
優(yōu)點:
1:服務(wù)消費者不用自己寫接口。
2:可提供好Dto,Vo等直接給服務(wù)消費者。
缺點:
1:service需要依賴jar包,如果依賴服務(wù)過多,jar也會過多。
2:給消費者暴露了過多的接口。部分與消費者無關(guān)的接口也暴露給對方。
方式二:
優(yōu)點:
1:無需依賴過多jar包。
2:消費者不要要過多接受消費者提供的方法。
缺點:
1:需要消費者自己實現(xiàn)接口。
2:嚴(yán)重依賴文檔。在實現(xiàn)接口時,對于所有信息都要有文檔定義。如:請求方式,請求參數(shù),返回值等。
3:自己完成Dto,Vo的編寫。
六、小結(jié)一下
兩種調(diào)用方式,我把知道的優(yōu)缺點放在這了。關(guān)于如何選擇,請根據(jù)需要自己抉擇,以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
后端報TypeError:Cannot?read?properties?of?null?(reading?‘
這篇文章主要給大家介紹了關(guān)于后端報TypeError:Cannot?read?properties?of?null?(reading?‘xxx‘)錯誤的解決辦法,這個錯誤是開發(fā)中常見的錯誤之一,需要的朋友可以參考下2023-05-05在CentOS系統(tǒng)中檢測Java安裝及運行jar應(yīng)用的方法
這篇文章主要介紹了在CentOS系統(tǒng)中檢測Java安裝及運行jar應(yīng)用的方法,同樣適用于Fedora等其他RedHat系的Linux系統(tǒng),需要的朋友可以參考下2015-06-06SpringBoot封裝響應(yīng)數(shù)據(jù)實現(xiàn)過程詳解
這篇文章主要介紹了SpringBoot封裝響應(yīng)數(shù)據(jù)實現(xiàn)過程,SpringBoot響應(yīng)數(shù)據(jù)封裝是指在SpringBoot應(yīng)用程序中,將返回的數(shù)據(jù)進(jìn)行封裝,以便于前端頁面或其他客戶端使用,感興趣想要詳細(xì)了解可以參考下文2023-05-05JAVA基于Arrays.sort()實現(xiàn)數(shù)組升序和降序
這篇文章主要介紹了JAVA基于Arrays.sort()實現(xiàn)數(shù)組升序和降序,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06Java JDBC API介紹與實現(xiàn)數(shù)據(jù)庫連接池流程
JDBC是指Java數(shù)據(jù)庫連接,是一種標(biāo)準(zhǔn)Java應(yīng)用編程接口( JAVA API),用來連接 Java 編程語言和廣泛的數(shù)據(jù)庫。從根本上來說,JDBC 是一種規(guī)范,它提供了一套完整的接口,允許便攜式訪問到底層數(shù)據(jù)庫,本篇文章我們來了解JDBC API及數(shù)據(jù)庫連接池2022-12-12Springboot整合Socket實現(xiàn)單點發(fā)送,廣播群發(fā),1對1,1對多實戰(zhàn)
本文主要介紹了Springboot整合Socket實現(xiàn)單點發(fā)送,廣播群發(fā),1對1,1對多實戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08