今天继续学习SpringCloud。
上篇我们讲了[服务网关Zuul和负载均衡Ribbon]
这一篇针对Feign和Hystrix详细说说
以下代码皆用最简单的代码示例,并非真正的业务代码
学习中用到的学习资料如下:
Feign
在实际开发中,还有另外一种更加便捷的方式来实现相同的功能,这就是Feign,现在就来使用Feign实现服务消费的负载均衡。
什么是Feign
与Ribbon一样,Feign也是由Netflix提供的,Feign是一个提供模版的声明式Web服务客户端,使用Feign可以简化Web Service客户端的编写,开发者可以通过简单的接口和注解来调用HTTP API,进行开发Spring Cloud也提供了Feign的集成组件:Spring Cloud Feign,它整合了Ribbon和Hystrix,具有可插拔,基于注解,负载均衡,服务熔断等多种便捷功能。
在Spring Cloud中使用Feign非常简单,Feign是一个声明式的Web服务客户端,所以只需要创建一个接口,同时在接口上添加相关注解即可完成服务提供方的接口绑定,相比较于Ribbon + RestTemplate的方式,Feign大大简化了代码的开发,Feign支持多种注释解,包括Feign注解,JAX-RS注解,Spring MVC注解等。Spring Cloud对Feign进行了优化,整合了Ribbon和Eureka,从而让Feign的使用更加方便。
Ribbon与Feign的区别
Feign是一种比Ribbon更加方便好用的Web服务客户端,那么两者有什么具体区别呢?Feign好用在哪里?
关于Ribbon和Feign的区别可以简单地理解为Ribbon是个通用的HTTP客户端工具,而Feign则是基于Ribbon来实现的,同时它更加灵活,使用起来也更加简单,上节课中我们通过Ribbon + RestTemplate实现了服务调用的负载均衡,相比较于这种方式,使用Feign可以直接通过声明式接口的形式来调用服务,非常方便,比Ribbon使用起来要更加完善,只需要创建接口并添加相关注解配置,即可实现服务消费的负载均衡。
Feign的特点
- Feign是一个声明式Web Service客户端。
- 支持Feign注解,JAX-RS注解,Spring MVC注解。
- Feign基于Ribbon实现,使用起来更加简单。
- Feign集成了Hystrix,具有服务熔断功能。
Feign代码实现
- 创建 Module,pom.xml
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
<version>2.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>2.0.2.RELEASE</version>
</dependency>
</dependencies>
- 创建配置文件 application.yml
server:
port: 8050
spring:
application:
name: feign
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
prefer-ip-address: true
- 创建启动类
package com.janeroad;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.openfeign.EnableFeignClients;
@SpringBootApplication
@EnableFeignClients
public class FeignApplication {
public static void main(String[] args) {
SpringApplication.run(FeignApplication.class,args);
}
}
- 创建声明式接口
package com.janeroad.feign;
import com.janeroad.entity.Student;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import java.util.Collection;
@FeignClient(value = "provider")
public interface FeignProviderClient {
@GetMapping("/student/findAll")