上一篇文章講到了負載均衡在Spring Cloud體系中的體現,其實Spring Cloud是提供了多種客戶端調用的組件,各個微服務都是以HTTP接口的形式暴露自身服務的,因此在調用遠程服務時就必須使用HTTP客戶端。我們可以使用JDK原生的URLConnection、Apache的Http Client、Netty的異步HTTP Client, Spring的RestTemplate。但是,用起來最方便、最優雅的還是要屬Feign了。今天這一篇文章是系列教程中第五篇,也是對負載均衡的第二篇,主要對Spring Cloud Feign的實戰。
本系列教程
【微服務】輕松搞定SpringCloud微服務目錄
本系列為連載文章,閱讀本文之前強烈建議您先閱讀前面幾篇。
Feign簡介
Feign是一種聲明式、模板化的HTTP客戶端,也是netflix公司組件。使用feign可以在遠程調用另外服務的API,如果調用本地API一樣。
我們知道,阿里巴巴的doubbo采用二進制的RPC協議進行底層通訊,客戶端可以使用類似本地方法一樣調用。那么,雖然Feign同樣可以有這種效果,但是底層還是通過HTTP協議調取restful的API的方式。
通過Feign, 我們能把HTTP遠程調用對開發者完全透明,得到與調用本地方法一致的編碼體驗。
Spring Cloud Feign
開始起飛
起飛之前,先說明一下,本篇文章還是會在之前文章的源碼繼續。因此同樣需要服務發現中心、服務配置中心、服務、客戶端等微服務,因此沿用之前的項目中的子項目。
創建客戶端服務
為了方便,可以直接復制上一片文章中的cloud-hyh-ribbon-test-client 子項目。並命名為新子項目。
配置客戶端Pom文件
<dependencies>
<!--服務發現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>
<!--測試啟動組件-->
<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>
<!--構建-->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
配置文件配置
對resources文件下配置文件進行配置。
eureka:
client:
service-url:
defaultZone: http://localhost:8081/eureka/
instance:
appname: feign-client
server:
port: 8093
spring:
application:
name: ribbon-client
啟動類編寫
創建子包以后,創建主類FeignApplication.java
/**
* @Description :啟動類,示范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的掃描。
創建服務層
創建文件夾service ,然后創建TestService.java。
/**
* @Description :測試feign接口服務
* @Author hanyahong
* @Date 2017/12/10- 12:43
* <p>
* 通過在本服務的service層直接調用其他服務的api層的API接口進行相關操作。
* cloud-service 是一個簡單服務,測試返回一個獲取博客名稱的接口。
*/
@FeignClient("cloud-service")
public interface TestService {
/**
* 調取博客名稱
*
* @return 博客名稱
*/
@GetMapping("/ribbon/name")
String getBlogName();
}
說明:
@FeignClient 注解:就是你要調用的微服務接口所在的服務名。
比如A服務想調用B服務的服務。就要填寫B服務的服務名。
@GetMapping注解:就是要調用的接口rest資源路徑。
API層接口
我們將創建一個接口,暴露出去,可以調用剛才服務層的這個接口。
/**
* @Description :博客操作API,對外暴露
* @Author hanyahong
* @Date 2017/12/10- 12:53
*/
@RestController
@RequestMapping(value = "/feign")
public class BlogApi {
/**
* 注入服務層接口
*/
@Autowired
TestService testService;
/**
* 通過Feign客戶端的方式,調用之前一個服務的API
*
* @return
*/
@RequestMapping("/blogName")
public String getBlogNameByFeign() {
return "通過feign方式得到:" + testService.getBlogName();
}
}
目錄參考

啟動項目群並測試
啟動注冊中心、配置中心、兩個相同配置服務、還有一個本文創建的客戶端cloud-hyh-test-feign.
查看是否啟動成功
訪問注冊中心,查看是否全部啟動。

已經啟動成功!
訪問測試
訪問地址http://localhost:8093/feign/blogName 路徑,查看是否成功返回需要的數據。
結果顯示:
通過feign方式得到:千萬之路剛開始-www.hanyahong.com-beijing該服務器端口8072
源碼
本文出處:http://www.hanyahong.com/
Github源碼:https://github.com/hanyahong/spring-cloud-microservice
轉發請注明出處!
