上一章節(jié),講解了SpringCloud如何通過(guò)RestTemplate+Ribbon去負(fù)載均衡消費(fèi)服務(wù)系冗,本章主要講述如何通過(guò)Feign去消費(fèi)服務(wù)淹仑。
一、Feign 簡(jiǎn)介:
Feign是一個(gè)便利的rest框架令杈,在Ribbon的基礎(chǔ)上進(jìn)行了一次改進(jìn)走敌,采用接口的方式,將需要調(diào)用的其他服務(wù)的方法定義成抽象方法逗噩,不需要自己構(gòu)建http請(qǐng)求掉丽,簡(jiǎn)化了調(diào)用跌榔。但是最后的原理還是通過(guò)ribbon在注冊(cè)服務(wù)器中找到服務(wù)實(shí)例,然后對(duì)請(qǐng)求進(jìn)行分配机打。
在工作中矫户,我們基本上都是使用Feign來(lái)進(jìn)行服務(wù)調(diào)用,因?yàn)镕eign使用起來(lái)就像是調(diào)用自身本地的方法一樣残邀,而感覺(jué)不到是調(diào)用遠(yuǎn)程方法皆辽,相當(dāng)舒服,它主要有3個(gè)優(yōu)點(diǎn)芥挣。
- feign本身里面就包含有了ribbon驱闷,具有負(fù)載均衡的能力
- fegin是一個(gè)采用基于接口的注解的編程方式,更加簡(jiǎn)便
- fegin整合了Hystrix空免,具有熔斷的能力
二空另、 準(zhǔn)備工作:
- 啟動(dòng)eureka-server 工程,eureka注冊(cè)中心就啟動(dòng)了蹋砚。
- 啟動(dòng)springcloud-eureka-client工程扼菠,springcloud-eureka-client工程的端口為9300。
- 將springcloud-eureka-client工程的application.properties文件中端口改成9400坝咐,然后再啟動(dòng)springcloud-eureka-client循榆。
通過(guò)上面步驟,我們就啟動(dòng)了端口9300墨坚,9400兩個(gè)一樣的springcloud-eureka-client服務(wù)模塊(為了測(cè)試feign的負(fù)載均衡能力)秧饮。
三、新建一個(gè)feign服務(wù):
- 新建一個(gè)spring-boot工程泽篮,取名為springcloud-feign-client盗尸,修改pox文件如下:
<parent>標(biāo)簽就是引入我們第一章節(jié)新建的父工程的pom.xml文件,具體可參考:[一起來(lái)學(xué)Spring Cloud | 第一章 :如何搭建一個(gè)多模塊的springcloud項(xiàng)目]
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.haly</groupId>
<artifactId>springcloud</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.haly</groupId>
<artifactId>springcloud-feign-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-ribbon-client</name>
<description>新建一個(gè)springcloud項(xiàng)目</description>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
- 修改application.properties文件如下
server.port=9600
spring.application.name=springcloud-feign-client
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
- 模塊啟動(dòng)類(lèi)需要增加注解@EnableFeignClients帽撑,表示開(kāi)啟Feign的功能
package com.haly;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
@SpringBootApplication
@EnableFeignClients
@EnableDiscoveryClient
public class SpringcloudFeignClientApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudFeignClientApplication.class, args);
}
}
- 定義一個(gè)feign接口泼各,通過(guò)@FeignClient(“服務(wù)名”),來(lái)指定調(diào)用哪個(gè)服務(wù)亏拉。本章案例中調(diào)用了springcloud-eureka-client服務(wù)的“/hello”接口
springcloud-eureka-client模塊中的hello接口历恐,具體實(shí)現(xiàn)可以參考:[一起來(lái)學(xué)Spring Cloud | 第二章:服務(wù)注冊(cè)和發(fā)現(xiàn)組件 (Eureka)]
ps:抽象方法的注解、方法名专筷、參數(shù)要和服務(wù)提供方保持一致(這里是與springcloud-eureka-client模塊中的 /hello方法保持一致)
package com.haly.romote;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
@FeignClient(value = "springcloud-eureka-client")
public interface FeignRemoteService {
@RequestMapping(value = "/hello",method = RequestMethod.GET)
public String hello(@RequestParam(value = "name") String name);
}
- controller層弱贼,對(duì)外暴露一個(gè)"/getHello"的API接口,給頁(yè)面測(cè)試磷蛹,通過(guò)上面定義的Feign客戶(hù)端FeignRemoteService來(lái)消費(fèi)服務(wù)吮旅。代碼如下:
package com.haly.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.haly.romote.FeignRemoteService;
@RestController
public class FeignController {
@Autowired
FeignRemoteService feignRemoteService;
@GetMapping(value = "/getHello")
public String getHello(@RequestParam String name) {
return feignRemoteService.hello(name);
}
}
- 啟動(dòng)各個(gè)服務(wù)模塊,服務(wù)注冊(cè)結(jié)果如下
image
訪問(wèn)地址 http://localhost:9600/getHello?name=young碼農(nóng) , 多次輪流訪問(wèn)頁(yè)面庇勃,出現(xiàn)9300檬嘀,9400服務(wù)接口返回結(jié)果,證明feign是整合了負(fù)載均衡功能
image
image
四责嚷、總結(jié):
加上本章節(jié)代碼后鸳兽,代碼目錄結(jié)構(gòu):
如果你對(duì)我的文章感興趣,可以觀看更多我的文章
[請(qǐng)點(diǎn)擊罕拂,前往我的博客:](https://www.cnblogs.com/haly)