一、Feign简介
Feign是一个声明式的伪Http客户端,它使得写Http客户端变得更简单。使用Feign,只需要创建一个接口并注解。它具有可插拔的注解特性,可使用Feign 注解和JAX-RS注解。Feign支持可插拔的编码器和解码器。Feign默认集成了Ribbon,并和Eureka结合,默认实现了负载均衡的效果。
创建一个springboot服务下边是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>demo</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>feign-client-service</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.3.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> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> <version>1.3.0.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> <version>1.3.0.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
配置文件
eureka: client: serviceUrl: # 注册中心地址 defaultZone: http://localhost:8888/eureka/ server: port: 8900 spring: application: name: service-feign datasource: #配置Mysql连接信息 url: jdbc:mysql://localhost:3306/ssh?characterEncoding=utf8 username: root password: 111111 #mongodb数据配置
在启动类加上如下注解开启Feign的功能:
@EnableDiscoveryClient @EnableFeignClients
定义一个ClientService接口,通过@ FeignClient(“服务名”),来指定调用哪个服务
@FeignClient(value = "service-test") public interface ClientService { @RequestMapping(value = "/getUsers",method = RequestMethod.GET) List<User> hello(); }
在controller层,对外暴露一个”/hi”的API接口,通过上面定义的Feign客户端SchedualServiceHi 来消费服务。代码如下:
@RestController public class HiController { @Autowired ClientService schedualServiceHi; @RequestMapping(value = "/hi",method = RequestMethod.GET) public List<User> sayHi(){ return schedualServiceHi.hello(); } }
启动创建的eureka服务 还有消费者服务。
浏览器访问http://localhost:8900/hi会发现调用了另外一个消费者端口为8889的服务,并有数据返回
完成。
这时的接口为
- 一个服务注册中心,eureka server,端口为8888
- 两个服务端口为8889,8900,分别向服务注册中心注册
- 当调用feign-clent-service的接口时,它会通过rest调用service-test的hi接口并返回数据,