• Spring Cloud OpenFeign 性能优化的4个方法


    OpenFeign 是 Spring 官方推出的一种声明式服务调用和负载均衡组件。它的出现就是为了替代已经进入停更维护状态的 Netflix Feign,是目前微服务间请求的常用通讯组件。

    1.超时设置

    OpenFeign 底层依赖Ribbon 框架,并且使用了 Ribbon 的请求连接超时时间和请求处理超时时间作为其超时时间,可以通过配置修改。
    通过修改 Ribbon 的超时时间:

    ribbon:
      ReadTimeout: 5000 
      ConnectionTimeout: 10000
    
    • 1
    • 2
    • 3

    直接修改 OpenFeign配置:

    feign:
      client:
        config:
          default: 
            connectTimeout: 
            readTimeout:
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    2. 请求连接

    OpenFeign 底层通信组件默认使用 JDK 自带的 URLConnection 对象进行 HTTP 请求的,因为没有使用连接池,所以性能不是很好。我们可以将 OpenFeign 的通讯组件,手动替换成像 Apache HttpClient 或 OKHttp 这样的专用通信组件,这些的专用通信组件自带连接池可以更好地对 HTTP 连接对象进行重用与管理,同时也能大大提升 HTTP 请求的效率。接下来我以 Apache HttpClient 为例,演示一下专用通讯组件的使用。

    2.1 引入 Apache HttpClient 依赖

    在项目的依赖管理文件 pom.xml 中添加以下配置:

    
    <dependency>
        <groupId>org.springframework.cloudgroupId>
        <artifactId>spring-cloud-starter-openfeignartifactId>
    dependency>
    
    <dependency>
        <groupId>io.github.openfeigngroupId>
        <artifactId>feign-httpclientartifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    2.2 开启 Apache HttpClient 使用

    启动 Apache HttpClient 组件,在项目配置文件 application.yml 中添加以下配置:

    feign:
      client:
        httpclient: # 开启 HttpClient
          enabled: true
    
    • 1
    • 2
    • 3
    • 4

    3. 数据压缩

    OpenFeign 默认不会开启数据压缩功能,但我们可以手动的开启它的 Gzip 压缩功能,这样可以极大的提高宽带利用率和加速数据的传输速度,在项目配置文件 application.yml 中添加以下配置:

    feign:
      compression:
        request:
          enabled: true 
          mime-types: text/xml,application/xml, application/json 
          min-request-size: 1024 
        response:
          enabled: true
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    4. 负载均衡策略

    OpenFeign 底层使用的是 Ribbon 做负载均衡的,它默认的负载均衡策略是轮询策略。
    除了轮询策略之外,我们还有其他 6 种内置的负载均衡策略可以选择,这些负载均衡策略如下:

    • 权重策略:WeightedResponseTimeRule,根据每个服务提供者的响应时间分配一个权重,响应时间越长,权重越小,被选中的可能性也就越低。
    • 最小连接数策略:BestAvailableRule,也叫最小并发数策略,它是遍历服务提供者列表,选取连接数最小的⼀个服务实例。如果有相同的最小连接数,那么会调用轮询策略进行选取。
    • 区域敏感策略:ZoneAvoidanceRule,根据服务所在区域(zone)的性能和服务的可用性来选择服务实例,在没有区域的环境下,该策略和轮询策略类似。
    • 可用敏感性策略:AvailabilityFilteringRule,先过滤掉非健康的服务实例,然后再选择连接数较小的服务实例。
    • 随机策略:RandomRule,从服务提供者的列表中随机选择一个服务实例。
    @Configuration
    public class MyRuleConfig {
    
        @Bean
        @LoadBalanced
        public IRule myRule(){
            return new RandomRule();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    5. 总结

    OpenFeign 是 Spring 官方推出的一种声明式服务调用和负载均衡组件,在生产环境中我们可以按照业务需要按需进行配置调整以求达到最好的性能。

    6. 彩蛋

    想要获取更多Java开发相关材料,请微信搜**【小白技术圈】**阅读,发送回复 G02获取Java经典面试题!欢迎大大们催更。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    PDF编辑软件哪个好用?PDF文档怎么编辑修改内容
    比特币全节点同步加速记录(使用Bitcoin Core钱包)
    接入电商数据平台官方开放平台API接口获取商品实时信息数据,销量,评论,详情页演示
    STM32F1与STM32CubeIDE编程实例-MAX7219驱动8位7段数码管(基于GPIO)
    微信小程序全局水印组件
    汽车一键启动智能系统功能作用
    读书笔记:c++对话系列,模板方法模式(Template Method Pattern)
    html5自定义属性--------Dataset
    kotlin语法快速入门-接口与接口实现(8)
    GeForce RTX 2080显卡驱动安装(linux系统)
  • 原文地址:https://blog.csdn.net/yangbaggio/article/details/133608336