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


上一篇文章講到了負載均衡在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();
    }
}

目錄參考

目錄參考.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
轉發請注明出處!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM