您好,登錄后才能下訂單哦!
Feign是一個聲明式的WebService客戶端。使用Feign能讓編寫WebService客戶端更加簡單,它的使用方法是定義一個接口,然后在接口上添加注解,同時也支持JAX-RS標準的注解。Feign也支持可插拔式的編碼器和×××。SpringCloud對Feign進行了封裝,使其支持SpringMVC標準注解和HttpMessageConverters。Feign可以與Eureka和Ribbon組合使用以支持負載均衡。
如何使用Feign?
添加Feign的依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
啟動入口加入:
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
最后別忘了最關鍵的這個.這個總是沒想到。千萬別忘了。hehe
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Dalston.SR3</version>
<type>pom</type>
<scope>import</scope>
</dependency>
定義的接口中 加入注解和請求服務:@FeignClient(name="service的名稱")
接口方法加入請求方法:@RequestMapping(method = RequestMethod.GET, value = "/hello")
至于service基本沒什么特別的。最要是client端
service 只要放入@RestController 以及@RequestMapping 及可
@FeignClient注解中的stores屬性可以是一個任意字符串,如果與Eureka組合使用,則stores應為Eureka中的服務名,Feign用它來創建一個Ribbon負載均衡器。也可以通過url屬性來指定一個地址,可以是完整的URL,也可以是一個主機名。標注了@FeignClient注解的接口,在ApplicationContext中的Bean實例名是這個接口的全限定名,同時這個Bean還有一個別名,為Bean名+FeignClient。
覆蓋Feign的默認配置
SpringCloud對Feign的封裝中一個核心的概念就是客戶端要有一個名字。每個客戶端隨時可以向遠程服務發起請求,并且每個服務都可以像使用@FeignClient注解一樣指定一個名字。SpringCloud會將所有的@FeignClient組合在一起創建一個新的ApplicationContext,并使用FeignClinetsConfiguration對Clients進行配置。配置中包括編碼器、×××和一個feign.Contract。
SpringCloud允許你通過configuration屬性完全控制Feign的配置信息,這些配置比FeignClientsConfiguration優先級要高
這樣就完成了一個基本的feign項目搭建了
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。