Spring Cloud:使用 Feign 实现负载均衡详解

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
EMR Serverless StarRocks,5000CU*H 48000GB*H
简介: Spring Cloud:使用 Feign 实现负载均衡详解

前面几篇文章,对 Ribbon 负载均衡做了详细的分析,这一节来介绍一下使用 Feign 负载均衡。在介绍之前,我们先来对 Feign 做一下简单的介绍,先来理解一下什么是 Feign。


1. Feign 是什么?


我们看一下官方的解释:Feign 是一个声明式 WebService 客户端。使用 Feign 能让编写的 WebService 客户端更加简洁,它的使用方法式定义一个接口,然后在上面添加注解。


Spring Cloud 对 Feign 进行了封装,使其支持了 Spring MVC 标准注解和 HttpMessageConverters。Feign 可以与 Eureka 和 Ribbon 组合使用以支持负载均衡。


2. 为什么要使用 Feign?


Feign 旨在使编写 Java Http 客户端变得更容易。前面在使用 Ribbon + RestTemplate 时,利用 RestTemplate 对 http 请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用


所以,Feign 在此基础上做了进一步的封装,由它来帮助我们定义和实现依赖服务接口的定义。使用 Feign 只需要创建一个接口并使用一个注解来配置它即可


这就类似于我们在 dao 层的接口上标注 @Mapper 注解一样。这样的话,即完成了对服务提供方的接口绑定,简化了使用 Spring Cloud Ribbon 时的开发量。我们用实例来说明。


3. Feign 的使用


3.1 依赖导入


<!--eureka Client-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<!-- feign的支持 -->
<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>


3.2 启动类注解配置


@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class OrderConsumerFeign {
   public static void main(String[] args) {
       SpringApplication.run(OrderConsumerFeign.class, args);
   }
}


启动类需要添加注解 @EnableFeignClients,表示启用 Feign 客户端。


3.3 Feign 客户端


我们先来回忆一下,提供订单的服务名称为:MICROSERVICE-ORDER,然后订单服务中提供的两个获取订单信息的接口url如下:


/**
* feign客户端
* @author shengwu ni
*/
@FeignClient(value = "MICROSERVICE-ORDER")
public interface OrderClientService {
   @GetMapping("/provider/order/get/{id}")
   TOrder getOrder(@PathVariable(value = "id") Long id);
   @GetMapping("/provider/order/get/list")
   List<TOrder> getAll();
}


可以看到,Feign 客户端要添加 @FeignClient 注解,value 属性表示作用到哪个微服务上,这里表示负载均衡作用到请求订单服务上。要记住,Feign 也是客户端的负载均衡。


方法内定义了两个接口,接口上即和普通的 SpringMVC 没什么区别,url 即订单提供服务的url。这就是 Feign 客户端,通过注解 + 接口的方式来和订单服务的接口绑定。


3.4 Feign 客户端的使用


定义好了 Feign 客户端接口后,我们就可以在代码里通过 @Resource 正常引入进来,然后通过普通的方法调用即可实现对订单服务的调用,如下:


@RestController
@RequestMapping("/consumer/order")
public class OrderConsumerController {
   /**
    * 上面定义的 Feign Client
    */
   @Resource
   private OrderClientService orderClientService;
   @GetMapping("/get/{id}")
   public TOrder getOrder(@PathVariable Long id) {
       return orderClientService.getOrder(id);
   }
   @GetMapping("/get/list")
   public List<TOrder> getAll() {
       return orderClientService.getAll();
   }
}


启动 eureka 集群、三个订单提供服务和这个带有 Feign 的服务消费方(端口 9001)。通过在浏览器中访问:http://localhost:9001//consumer/order/get/1 可以看到,轮流访问三个订单服务。说明 Feign 默认是集成了 Ribbon 的轮询方案。


4. Feign 如何结合 Ribbon 切换均衡算法


以上就是 Feign 的使用,很简单,也符合我们平时的接口调用习惯。但是这是默认的轮询负载均衡算法。在上一节我们知道,Ribbon 中支持很多自带的均衡算法,我们只要在代码中根据具体情况,选择合适的均衡算法即可。甚至我们可以选择自己自定义的均衡算法。


那么使用 Feign 的时候,如何去切换到 Ribbon 中其他均衡策略呢?甚至切换到自定义的策略呢?


也很简单,我们可以在 application.yml 配置文件中来指定,如下:


# feign和ribbon结合,指定策略。feign默认的是轮询的策略,这里的配置可以自定义
MICROSERVICE-ORDER:
 ribbon:
   NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule


MICROSERVICE-ORDER 表示作用到哪个微服务,com.netflix.loadbalancer.RandomRule 即前面介绍 Ribbon 时里面的随机策略,当然,我们也可以指定为其他策略,包括我们自己定义的,只要把相应的包路径写到这即可,很方便。


重新启动一下服务消费方的程序,访问上面那个测试 url,可以看到三个订单服务是随机调用的,说明配置生效。


相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
2月前
|
负载均衡 算法 Java
Spring Cloud全解析:负载均衡算法
本文介绍了负载均衡的两种方式:集中式负载均衡和进程内负载均衡,以及常见的负载均衡算法,包括轮询、随机、源地址哈希、加权轮询、加权随机和最小连接数等方法,帮助读者更好地理解和应用负载均衡技术。
|
3月前
|
开发框架 负载均衡 Java
当热门技术负载均衡遇上 Spring Boot,开发者的梦想与挑战在此碰撞,你准备好了吗?
【8月更文挑战第29天】在互联网应用开发中,负载均衡至关重要,可避免单服务器过载导致性能下降或崩溃。Spring Boot 作为流行框架,提供了强大的负载均衡支持,通过合理分配请求至多台服务器,提升系统可用性与可靠性,优化资源利用。本文通过示例展示了如何在 Spring Boot 中配置负载均衡,包括添加依赖、创建负载均衡的 `RestTemplate` 实例及服务接口调用等步骤,帮助开发者构建高效、稳定的应用。随着业务扩展,掌握负载均衡技术将愈发关键。
73 6
|
3天前
|
负载均衡 算法 Java
除了 Ribbon,Spring Cloud 中还有哪些负载均衡组件?
这些负载均衡组件各有特点,在不同的场景和需求下,可以根据项目的具体情况选择合适的负载均衡组件来实现高效、稳定的服务调用。
15 5
|
21天前
|
JSON Java 数据格式
【微服务】SpringCloud之Feign远程调用
本文介绍了使用Feign作为HTTP客户端替代RestTemplate进行远程调用的优势及具体使用方法。Feign通过声明式接口简化了HTTP请求的发送,提高了代码的可读性和维护性。文章详细描述了Feign的搭建步骤,包括引入依赖、添加注解、编写FeignClient接口和调用代码,并提供了自定义配置的示例,如修改日志级别等。
49 1
|
2月前
|
负载均衡 Java Nacos
SpringCloud基础2——Nacos配置、Feign、Gateway
nacos配置管理、Feign远程调用、Gateway服务网关
SpringCloud基础2——Nacos配置、Feign、Gateway
|
2月前
|
前端开发 API 微服务
SpringCloud微服务之间使用Feign调用不通情况举例
SpringCloud微服务之间使用Feign调用不通情况举例
447 2
|
2月前
|
负载均衡 Java 对象存储
负载均衡策略:Spring Cloud与Netflix OSS的最佳实践
负载均衡策略:Spring Cloud与Netflix OSS的最佳实践
46 2
|
2月前
|
负载均衡 Java Nacos
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
微服务介绍、SpringCloud、服务拆分和远程调用、Eureka注册中心、Ribbon负载均衡、Nacos注册中心
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
|
2月前
|
Java API 开发者
【已解决】Spring Cloud Feign 上传文件,提示:the request was rejected because no multipart boundary was found的问题
【已解决】Spring Cloud Feign 上传文件,提示:the request was rejected because no multipart boundary was found的问题
330 0
|
4月前
|
负载均衡 Java Spring
Spring cloud gateway 如何在路由时进行负载均衡
Spring cloud gateway 如何在路由时进行负载均衡
475 15
下一篇
无影云桌面