【微服務】之五:輕鬆搞定SpringCloud微服務-調用遠程組件Feign

上一篇文章講到了負載均衡在Spring Cloud體系中的體現,其實Spring Cloud是提供了多種客戶端調用的組件,各個微服務都是以HTTP接口的形式暴露自身服務的,所以在調用遠程服務時就必須使用HTTP客戶端。咱們可使用JDK原生的URLConnection、Apache的Http Client、Netty的異步HTTP Client, Spring的RestTemplate。可是,用起來最方便、最優雅的仍是要屬Feign了。今天這一篇文章是系列教程中第五篇,也是對負載均衡的第二篇,主要對Spring Cloud Feign的實戰。html

本系列教程

【微服務】輕鬆搞定SpringCloud微服務目錄
本系列爲連載文章,閱讀本文以前強烈建議您先閱讀前面幾篇。java

Feign簡介

Feign是一種聲明式、模板化的HTTP客戶端,也是netflix公司組件。使用feign能夠在遠程調用另外服務的API,若是調用本地API同樣。
咱們知道,阿里巴巴的doubbo採用二進制的RPC協議進行底層通信,客戶端可使用相似本地方法同樣調用。那麼,雖然Feign一樣能夠有這種效果,可是底層仍是經過HTTP協議調取restful的API的方式。
經過Feign, 咱們能把HTTP遠程調用對開發者徹底透明,獲得與調用本地方法一致的編碼體驗。git

Spring Cloud Feign

開始起飛

起飛以前,先說明一下,本篇文章仍是會在以前文章的源碼繼續。所以一樣須要服務發現中心、服務配置中心、服務、客戶端等微服務,所以沿用以前的項目中的子項目。github

建立客戶端服務

爲了方便,能夠直接複製上一片文章中的cloud-hyh-ribbon-test-client 子項目。並命名爲新子項目。web

配置客戶端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文件下配置文件進行配置。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

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();
    }
}

目錄參考

目錄參考.png

啓動項目羣並測試

啓動註冊中心、配置中心、兩個相同配置服務、還有一個本文建立的客戶端cloud-hyh-test-feign.

查看是否啓動成功

訪問註冊中心,查看是否所有啓動。
image.png

已經啓動成功!

訪問測試

訪問地址http://localhost:8093/feign/blogName 路徑,查看是否成功返回須要的數據。

結果顯示:

經過feign方式獲得:千萬之路剛開始-www.hanyahong.com-beijing該服務器端口8072

源碼

本文出處:http://www.hanyahong.com/ Github源碼:https://github.com/hanyahong/spring-cloud-microservice 轉發請註明出處!

相關文章
相關標籤/搜索