一、场景描述
我们可以通过ribbon来实现服务间的调用,但是当服务很多的时候调用方法写起来比较麻烦,而且也不容易管理。feign整合了ribbon,以接口的方式来调用服务,更加的方便
二、feign实现
- Idea-->file-->new-->project-->spring initializr-->next-->修改必要信息-->next
- 分别选择Cloud Routing-->Feign还有Cloud Discovery-->Eureka Discovery
- 点击next-->finish
- 我们查看生成项目里面的pom文件内容如下:
<?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>
<groupId>com.example</groupId>
<artifactId>eurekafeign</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>eurekafeign</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
- 我们可以看到其中两个重要的依赖,我们再现有项目添加feign调用功能的时候只需要把下面两个依赖添加即可
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
- 在我们的启动类中添加@EnableFeignClients。用于启用feign组建
- 在application.properties文件中添加eureka的配置,使注册中心可用。配置请参照注册中心实战篇,内容如下:
spring.application.name=eurekafeign
server.port=8084
eureka.client.serviceUrl.defaultZone=http://eureka1:8001/eureka/ ,http://eureka1:8002/eureka/,http://eureka1:8003/eureka/
- 我们做一个简单的调用实例代码如下:
==DemoServiceInterface== 这是核心内容,是Feign的Client接口,
@FeignClient("DEMO")指定我们这个接口会使用eureka注册中心的DEMO服务中的服务
@RequestMapping("/hello")表示我们调用DEMO服务中的hello服务
package com.example.eurekafeign;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestMapping;
@Component
@FeignClient("DEMO")
public interface DemoServiceInterface {
@RequestMapping("/hello")
String hello();
}
- 在我们需要调用demo的hello服务的地方注入DemoServiceInterface,直接调用hello方法即可完成调用。
package com.example.eurekafeign;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
public class HelloWord {
@Resource
private DemoServiceInterface demoServiceInterface;
@RequestMapping(value="hello")
@ResponseBody
public String helloWord(){
return demoServiceInterface.hello();
}
}
++敲黑板++
feign内部集成了Ribbon所以通过serviceid找到服务后,会通过ribbon自动实现服务访问的负载均衡,可以通过定义ribbon的负载均衡方法来实现自己想要的
在接口的方法前面需要定义该方法访问路径和访问方法和编码格式等信息
对于请求参数也可以通过@requestBody或者@RequestParameter的value方法进行设置,这里就使用和入参名同名的参数设定