首页 > 其他分享 >SpringCloud入门之设置OpenFeign 压缩 超时时间 重试等

SpringCloud入门之设置OpenFeign 压缩 超时时间 重试等

时间:2024-06-14 10:33:34浏览次数:36  
标签:Retryer feign OpenFeign SpringCloud 配置 重试 import 日志 yml

文章目录


前言

通过yml中设置一些属性,就可以让OpenFeign的功能更加强大,它不仅限于服务间的调用,还有请求重试、压缩等功能。


一、为什么要配置

在所有服务都正常的情况下仅仅使用FeignClient是没有问题的,但总会是会有各种万一的出现,比如下游服务异常一直请求不通、服务500等等一些问题,所以我们要配置一些属性来应对。


二、配置属性

在进行yml相关配置之前,先加一些代码,保证在测试yml属性时可以看到效果。

1. 代码

import feign.Logger;
import feign.Retryer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import static java.util.concurrent.TimeUnit.SECONDS;

@Configuration
public class MyFeignConfig {

    @Bean
    public Retryer myRetryer() {
    // 看情况选择一个就行
//        return new Retryer.Default();
//        return new Retryer.Default(100, SECONDS.toMillis(1), 2); // 1秒内重试3次,时间间隔100毫秒
        return Retryer.NEVER_RETRY;
    }

    @Bean
    public Logger.Level feignLoggerLevel() {

        return Logger.Level.FULL;
    }
}

2. yml配置

2.1 开启Feign日志

针对FeignClient所在的类开启debug日志输出

logging:
  level:
    com.ukeren.springcloud.feign.api.PaymentServiceFeign: debug

2.2 读取超时和连接超时

default表示全部服务都用这个配置,如果想要为每个服务都配置一个的话,与default同级别,服务配置会覆盖默认配置

feign:
  client:
    config:
      default:
        connectTimeout: 5000
        readTimeout: 5000
      backend-service-1:
        connectTimeout: 1000
        readTimeout: 1000

connectTimeout:避免服务器处理时间过长而阻塞调用方
readTimeout:避免返回响应时消费太多时间
效果图,如下:
在这里插入图片描述

2.3 gzip压缩

feign:
  compression:
    request:
      enabled: true
      min-request-size: 2048
      mime-types: text/xml,application/xml,application/json
    response:
      enabled: true
      useGzipDecoder: true

未开启压缩的日志输出,如下图
在这里插入图片描述
开启压缩的日志输出,如下图
在这里插入图片描述

2.4 变更httpclient客户端

启用hc5,比自带的httpclient性能高

feign:
  httpclient:
    hc5:
      enabled: true

3.日志输出说明

开启的debug日志输出,在测试环境下用就可以了,其他环境用不到的话,删掉,或者改为info级别的日志输出

logging:
  level:
    com.ukeren.springcloud.feign.api.PaymentServiceFeign: info

标签:Retryer,feign,OpenFeign,SpringCloud,配置,重试,import,日志,yml
From: https://blog.csdn.net/tsstep/article/details/139578712

相关文章

  • SpringCloudNetflix组件整合
    SpringCloudNetflix组件整合Eureka注册中心Eureka是什么Eureka是netflix的一个子模块,也是核心模块之一,Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移。服务注册与发现对于微服务架构来说是非常重要的,有了服务发现和注册,只需要使用服务的标......
  • 小宋的SpringCloud学习记录day02
    基于Restful风格实现下列接口:今天我们继续昨天的课程来学习一下MybatisPlus的核心功能——IService接口下面是我们需要在pom文件中要引入的依赖<!--swagger--><dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-openapi2-spring-boot-sta......
  • 小宋的SpringCloud学习记录day01
    MybatisPlus条件构造器基于QueryWrapper的查询MybatisPlus中写好的QueryWrapper方法省去了编写复杂sql语句的繁琐,直接把各种条件集成为对应的方法需求:1.查询出名字中带o的,存款大于等于10000的人的id、username、info、balance字段2.更新用户名为jack的用户余额为2000......
  • SpringCloud-OpenFeign拓展-连接池、最佳使用方法、日志输出
    目录1OpenFeign连接池1.1常见连接类型1.2连接池使用方法1.2.1引入依赖1.2.2开启连接池功能1.2.3配置完成,重启实例即可,底层将更改设置。2OpenFeign最佳使用方法2.1每个微服务都是单独的project,内部有三个独立模块2.2每个微服务都是一个module,一个project,内设......
  • 门面模式Api网关(SpringCloudGateway)
    1.前言        当前通过Eureka、Nacos解决了服务注册和服务发现问题,使用SpringCloudLoadBalance解决了负载均衡的需求,同时借助OpenFeign实现了远程调用。然而,现有的微服务接口都直接对外暴露,容易被外部访问。为保障对外服务的安全性,通常在服务端实现的微服务接口会......
  • 通过网关实现登录验证以及微服务获取服务和OpenFeign传递用户
     网关登录校验单体架构时我们只需要完成一次用户登录、身份校验,就可以在所有业务中获取到用户信息。而微服务拆分后,每个微服务都独立部署,不再共享数据。也就意味着每个微服务都需要做登录校验,这显然不可取。鉴权思路分析我们的登录是基于JWT来实现的,校验JWT的算法复杂,而且......
  • 网关SpringCloudGateway配置
    1.2.快速入门如何利用网关实现请求路由。由于网关本身也是一个独立的微服务,因此也需要创建一个模块开发功能。大概步骤如下:创建网关微服务引入SpringCloudGateway、NacosDiscovery依赖编写启动类配置网关路由 1.2.1.创建项目首先,我们要在hmall下创建一个新的module,命......
  • SpringCloud 负载均衡 spring-cloud-starter-loadbalancer
    简述spring-cloud-starter-loadbalancer是SpringCloud中的一个组件,它提供了客户端负载均衡的功能。在SpringCloud的早期版本中,NetflixRibbon被广泛用作客户端负载均衡器,但随着时间推移和NetflixRibbon进入维护模式,SpringCloud社区开始转向更灵活、更易于维护......
  • OpenFeign的配置和使用
    OpenFeign利用Nacos实现了服务的治理,利用RestTemplate实现了服务的远程调用。但是远程调用的代码太复杂了,而且这种调用方式,与原本的本地方法调用差异太大,编程时的体验也不统一,一会儿远程调用,一会儿本地调用。因此,我们必须想办法改变远程调用的开发模式,让远程调用像本地方法调......
  • MongoDB CRUD操作:可重试写入
    MongoDBCRUD操作:可重试写入文章目录MongoDBCRUD操作:可重试写入使用的先决条件部署的限制支持的存储引擎3.6+MongoDB驱动程序MongoDB版本写确认可重试写入和多文档事务启用可重试写入MongoDB驱动mongosh可重试的写操作行为持续的网络错误故障切换周期诊断针对本地......