返回顶部
首页 > 资讯 > 精选 >Spring Cloud中如何使用Feign 实现负载均衡
  • 446
分享到

Spring Cloud中如何使用Feign 实现负载均衡

2023-06-04 08:06:49 446人浏览 薄情痞子
摘要

spring cloud中如何使用Feign 实现负载均衡,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。下面来介绍一下使用 Feign 负载均衡。在介绍之前,我们先来对 Fei

spring cloud中如何使用Feign 实现负载均衡,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

下面来介绍一下使用 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如下:


@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 {

   
   @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,可以看到三个订单服务是随机调用的,说明配置生效。

看完上述内容,你们掌握Spring Cloud中如何使用Feign 实现负载均衡的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: Spring Cloud中如何使用Feign 实现负载均衡

本文链接: https://lsjlt.com/news/237011.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Spring Cloud中如何使用Feign 实现负载均衡
    Spring Cloud中如何使用Feign 实现负载均衡,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。下面来介绍一下使用 Feign 负载均衡。在介绍之前,我们先来对 Fei...
    99+
    2023-06-04
  • Spring Cloud Alibaba负载均衡实现方式
    目录一、负载均衡的两种方式服务器端负载均衡客户端侧负载均衡二、手写一个客户端侧负载均衡器三、使用Ribbon实现负载均衡一、负载均衡的两种方式 服务器端负载均衡 传统的方式前端发送请...
    99+
    2024-04-02
  • Spring Cloud中如何使用Ribbon实现客户端的负载均衡
    今天小编给大家分享一下Spring Cloud中如何使用Ribbon实现客户端的负载均衡的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2023-06-04
  • Spring cloud alibaba之Ribbon负载均衡实现方案
    目录1.什么是Ribbon1.1客户端的负载均衡1.2服务器端的负载均衡1.3常见负载均衡算法2.Nacos使用Ribbon3.Ribbon负载均衡策略3.1常用负载均衡描述3.3修...
    99+
    2024-04-02
  • spring cloud集成ribbon负载均衡怎么实现
    这篇文章主要介绍“spring cloud集成ribbon负载均衡怎么实现”,在日常操作中,相信很多人在spring cloud集成ribbon负载均衡怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-21
  • Spring Cloud中如何自定义Ribbon负载均衡策略
    小编给大家分享一下Spring Cloud中如何自定义Ribbon负载均衡策略,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 主启动类处理还是使用上一节的客户...
    99+
    2023-06-04
  • 负载均衡如何实现
    负载均衡是通过将网络请求分发到多个服务器上,以实现对服务器资源的均衡利用,提高系统的性能和可用性。实现负载均衡可以采用以下几种方法:...
    99+
    2023-09-02
    负载均衡
  • Spring Cloud中的负载均衡策略是什么
    本篇内容介绍了“Spring Cloud中的负载均衡策略是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!IRule这是所有负载均衡策略的...
    99+
    2023-06-19
  • 深入浅析spring cloud中的Ribbon负载均衡
    这期内容当中小编将会给大家带来有关深入浅析spring cloud中的Ribbon负载均衡,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、负载均衡负载均衡(Load Balance): 建立在现有网络结...
    99+
    2023-05-31
    spring cloud ribbon 负载均衡
  • LeetCode中如何使用Python实现Spring框架的负载均衡?
    在现代的互联网应用中,负载均衡已经成为了一个非常重要的组件。负载均衡可以让我们的应用更加健壮、更加高效,同时也可以让我们更加容易地扩展我们的应用。Spring框架是一个非常流行的Java框架,它提供了很多强大的功能,其中就包括负载均衡。在...
    99+
    2023-06-17
    leetcode load spring
  • Spring Cloud Ribbon 负载均衡使用策略示例详解
    目录一、前言二、什么是 Ribbon2.1 ribbon简介2.1.1  ribbon在负载均衡中的角色2.2 客户端负载均衡2.3 服务端负...
    99+
    2023-03-13
    Spring Cloud Ribbon 负载均衡使用策略 Spring Cloud Ribbon 负载均衡策略
  • Tomcat中如何实现负载均衡
    在Tomcat中实现负载均衡可以通过以下几种方法实现: 使用Apache HTTP服务器作为前端负载均衡器:在这种方法中,可以使...
    99+
    2024-04-23
    Tomcat
  • 如何使用Nginx+Tomcat实现负载均衡
    这篇“如何使用Nginx+Tomcat实现负载均衡”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何使用Nginx+Tomc...
    99+
    2023-06-30
  • Spring Cloud Ribbon 中的 7 种负载均衡策略的实现方法
    目录Ribbon 介绍负载均衡设置7种负载均衡策略1.轮询策略2.权重策略3.随机策略4.最小连接数策略5.重试策略6.可用性敏感策略7.区域敏感策略项目源码总结负载均衡通器常有两种...
    99+
    2024-04-02
  • ngnix如何实现负载均衡
    nginx可以通过多种方式实现负载均衡,以下是两种常见的方式:1. 基于IP Hash的负载均衡:nginx根据客户端的IP地址将请...
    99+
    2023-09-07
    ngnix 负载均衡
  • nginx如何实现负载均衡
    Nginx可以通过以下几种方式实现负载均衡:1. 轮询(Round Robin):Nginx默认使用轮询算法,将请求依次分配给不同的...
    99+
    2023-09-02
    nginx 负载均衡
  • nacos负载均衡如何实现
    Nacos提供了两种方式来实现负载均衡:客户端负载均衡和服务端负载均衡。1. 客户端负载均衡:在客户端进行负载均衡,客户端会通过Na...
    99+
    2023-09-04
    nacos
  • redis如何实现负载均衡
    要实现Redis的负载均衡,可以采取以下几种方式:1. 客户端分片:将数据按照一定的规则分散存储在多个Redis实例中,客户端在访问...
    99+
    2023-09-07
    redis 负载均衡
  • SpringCloud中如何利用Ribbon实现负载均衡
    SpringCloud中如何利用Ribbon实现负载均衡,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先在pom文件添加Fegin的依赖包。  <d...
    99+
    2023-06-05
  • Apache的负载均衡如何实现
    Apache的负载均衡可以通过以下几种常见的方式来实现: 使用Apache的内置模块mod_proxy和mod_proxy_balancer来实现负载均衡。mod_proxy_balancer模块可以将请求分发到多个后端服务器上,实现负...
    99+
    2024-07-05
    apache
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作