四、Feign负载均衡
1. 概念
前面在使用Ribbon+RestTemplate时,利用RestTemplate对http请求的封装处理,形成了一套模板化的调用方法。
但在实际开发中,由于对服务依赖的调用可能不止一处,往往一个借口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用。
因此,Feign在此基础上做了进一步封装,由他来帮助我们实现依赖服务接口的定义。在Feign的实现下,我们只需要创建一个接口,并使用注解的方式配置,即可完成对服务提供方的接口绑定。简化了使用SpringCloud Ribbon时,自动封装服务调用客户端的开发量。
简单来说,Feign集成了Ribbon,利用Ribbon维护了服务列表信息,且通过轮询策略实现客户端的负载均衡。此外,Feign只需要定义服务绑定接口且以声明式的方式,优雅而简单的实现了服务调用,使得编写Java Http客户端变得更容易。
2. 负载均衡配置
2.1 新建项目
创建一个新项目service-order-feign(为了与之前的service-order做区分),作为一个消费者服务。
创建方式即在工程spring-cloud-demo下新建module,这里不再赘述。
2.2 引入依赖
由于Feign整合了Ribbon,Ribbon配合Eureka使用,因此需要分别引入依赖spring-cloud-starter-ribbon、spring-cloud-starter-feign及spring-cloud-starter-eureka。
<dependencies>
<!-- Ribbon相关:Ribbon需要与Eureka整合,作为客户端 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency