上一篇文章講到了負(fù)載均衡在Spring Cloud體系中的體現(xiàn)据德,其實(shí)Spring Cloud是提供了多種客戶端調(diào)用的組件,各個(gè)微服務(wù)都是以HTTP接口的形式暴露自身服務(wù)的鳄乏,因此在調(diào)用遠(yuǎn)程服務(wù)時(shí)就必須使用HTTP客戶端跷车。我們可以使用JDK原生的URLConnection、Apache的Http Client橱野、Netty的異步HTTP Client, Spring的RestTemplate朽缴。但是,用起來最方便水援、最優(yōu)雅的還是要屬Feign了密强。今天這一篇文章是系列教程中第五篇,也是對(duì)負(fù)載均衡的第二篇蜗元,主要對(duì)Spring Cloud Feign的實(shí)戰(zhàn)或渤。
本系列教程
【微服務(wù)】輕松搞定SpringCloud微服務(wù)目錄
本系列為連載文章,閱讀本文之前強(qiáng)烈建議您先閱讀前面幾篇奕扣。
Feign簡(jiǎn)介
Feign是一種聲明式薪鹦、模板化的HTTP客戶端,也是netflix公司組件惯豆。使用feign可以在遠(yuǎn)程調(diào)用另外服務(wù)的API,如果調(diào)用本地API一樣池磁。
我們知道,阿里巴巴的doubbo采用二進(jìn)制的RPC協(xié)議進(jìn)行底層通訊楷兽,客戶端可以使用類似本地方法一樣調(diào)用地熄。那么,雖然Feign同樣可以有這種效果芯杀,但是底層還是通過HTTP協(xié)議調(diào)取restful的API的方式离斩。
通過Feign, 我們能把HTTP遠(yuǎn)程調(diào)用對(duì)開發(fā)者完全透明瘪匿,得到與調(diào)用本地方法一致的編碼體驗(yàn)跛梗。
Spring Cloud Feign
開始起飛
起飛之前,先說明一下棋弥,本篇文章還是會(huì)在之前文章的源碼繼續(xù)核偿。因此同樣需要服務(wù)發(fā)現(xiàn)中心、服務(wù)配置中心顽染、服務(wù)漾岳、客戶端等微服務(wù),因此沿用之前的項(xiàng)目中的子項(xiàng)目粉寞。
創(chuàng)建客戶端服務(wù)
為了方便尼荆,可以直接復(fù)制上一片文章中的cloud-hyh-ribbon-test-client 子項(xiàng)目。并命名為新子項(xiàng)目唧垦。
配置客戶端Pom文件
<dependencies>
<!--服務(wù)發(fā)現(xiàn)eureka組件 依賴-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<!--web支持 依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--測(cè)試啟動(dòng)組件-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<!--feign依賴 配置-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
</dependencies>
<!--構(gòu)建-->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
配置文件配置
對(duì)resources文件下配置文件進(jìn)行配置捅儒。
eureka:
client:
service-url:
defaultZone: http://localhost:8081/eureka/
instance:
appname: feign-client
server:
port: 8093
spring:
application:
name: ribbon-client
啟動(dòng)類編寫
創(chuàng)建子包以后,創(chuàng)建主類FeignApplication.java
/**
* @Description :啟動(dòng)類,示范feign
* @Author hanyahong
* @Date 2017/12/10- 07:00
*/
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class FeignClientApplication {
public static void main(String[] args) {
SpringApplication.run(FeignClientApplication.class, args);
}
}
說明:
@EnableFeignClients :該注解是開啟feign的掃描巧还。
創(chuàng)建服務(wù)層
創(chuàng)建文件夾service ,然后創(chuàng)建TestService.java鞭莽。
/**
* @Description :測(cè)試feign接口服務(wù)
* @Author hanyahong
* @Date 2017/12/10- 12:43
* <p>
* 通過在本服務(wù)的service層直接調(diào)用其他服務(wù)的api層的API接口進(jìn)行相關(guān)操作。
* cloud-service 是一個(gè)簡(jiǎn)單服務(wù)麸祷,測(cè)試返回一個(gè)獲取博客名稱的接口澎怒。
*/
@FeignClient("cloud-service")
public interface TestService {
/**
* 調(diào)取博客名稱
*
* @return 博客名稱
*/
@GetMapping("/ribbon/name")
String getBlogName();
}
說明:
@FeignClient 注解:就是你要調(diào)用的微服務(wù)接口所在的服務(wù)名。
比如A服務(wù)想調(diào)用B服務(wù)的服務(wù)阶牍。就要填寫B(tài)服務(wù)的服務(wù)名喷面。
@GetMapping注解:就是要調(diào)用的接口rest資源路徑。
API層接口
我們將創(chuàng)建一個(gè)接口走孽,暴露出去乖酬,可以調(diào)用剛才服務(wù)層的這個(gè)接口。
/**
* @Description :博客操作API融求,對(duì)外暴露
* @Author hanyahong
* @Date 2017/12/10- 12:53
*/
@RestController
@RequestMapping(value = "/feign")
public class BlogApi {
/**
* 注入服務(wù)層接口
*/
@Autowired
TestService testService;
/**
* 通過Feign客戶端的方式咬像,調(diào)用之前一個(gè)服務(wù)的API
*
* @return
*/
@RequestMapping("/blogName")
public String getBlogNameByFeign() {
return "通過feign方式得到:" + testService.getBlogName();
}
}
目錄參考
啟動(dòng)項(xiàng)目群并測(cè)試
啟動(dòng)注冊(cè)中心、配置中心生宛、兩個(gè)相同配置服務(wù)县昂、還有一個(gè)本文創(chuàng)建的客戶端cloud-hyh-test-feign.
查看是否啟動(dòng)成功
訪問注冊(cè)中心,查看是否全部啟動(dòng)陷舅。
已經(jīng)啟動(dòng)成功倒彰!
訪問測(cè)試
訪問地址http://localhost:8093/feign/blogName 路徑,查看是否成功返回需要的數(shù)據(jù)莱睁。
結(jié)果顯示:
通過feign方式得到:千萬之路剛開始-www.hanyahong.com-beijing該服務(wù)器端口8072
源碼
本文出處:http://www.hanyahong.com/
Github源碼:https://github.com/hanyahong/spring-cloud-microservice
轉(zhuǎn)發(fā)請(qǐng)注明出處待讳!