上一篇文章講到了負載均衡在Spring Cloud體系中的體現,其實Spring Cloud是提供了多種客戶端調用的組件,各個微服務都是以HTTP接口的形式暴露自身服務的,所以在調用遠程服務時就必須使用HTTP客戶端。咱們可使用JDK原生的URLConnection、Apache的Http Client、Netty的異步HTTP Client, Spring的RestTemplate。可是,用起來最方便、最優雅的仍是要屬Feign了。今天這一篇文章是系列教程中第五篇,也是對負載均衡的第二篇,主要對Spring Cloud Feign的實戰。html
【微服務】輕鬆搞定SpringCloud微服務目錄
本系列爲連載文章,閱讀本文以前強烈建議您先閱讀前面幾篇。java
Feign是一種聲明式、模板化的HTTP客戶端,也是netflix公司組件。使用feign能夠在遠程調用另外服務的API,若是調用本地API同樣。
咱們知道,阿里巴巴的doubbo採用二進制的RPC協議進行底層通信,客戶端可使用相似本地方法同樣調用。那麼,雖然Feign一樣能夠有這種效果,可是底層仍是經過HTTP協議調取restful的API的方式。
經過Feign, 咱們能把HTTP遠程調用對開發者徹底透明,獲得與調用本地方法一致的編碼體驗。git
起飛以前,先說明一下,本篇文章仍是會在以前文章的源碼繼續。所以一樣須要服務發現中心、服務配置中心、服務、客戶端等微服務,所以沿用以前的項目中的子項目。github
爲了方便,能夠直接複製上一片文章中的cloud-hyh-ribbon-test-client 子項目。並命名爲新子項目。web
<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文件下配置文件進行配置。spring
eureka: client: service-url: defaultZone: http://localhost:8081/eureka/ instance: appname: feign-client server: port: 8093 spring: application: name: ribbon-client
建立子包之後,建立主類FeignApplication.javaapi
/** * @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。restful
/** * @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資源路徑。app
咱們將建立一個接口,暴露出去,能夠調用剛纔服務層的這個接口。
/** * @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 轉發請註明出處!