springboot配置resilience4j全过程

 更新时间:2024年05月17日 16:49:11   作者:wfh小黑屋里的小黄花  
这篇文章主要介绍了springboot配置resilience4j全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

springboot配置resilience4j

resilience4j-ratelimiter:流量控制

单位时间内,控制访问方法的数量

yml配置:

resilience4j.ratelimiter:
  instances:
    backendA: # 名称
      limit-for-period: 3 #限制连续请求3次
      limit-refresh-period: 1s #1s刷新统计值
      timeout-duration: 5s #超时等待时长
    backendB: # 名称
      limit-for-period: 5 #限制连续请求5次
      limit-refresh-period: 1s #1s刷新统计值
      timeout-duration: 10s #超时等待时长

使用:

@RateLimiter(name = "backendA")

resilience4j-retry:重试

异常重试

resilience4j.retry:
  instances:
    backendA:
      max-retry-attempts: 3 # 重试次数
      wait-duration: 600 # 重试等待时间
      # 判断异常是否需要重试
      retryExceptionPredicate: com.test.manager.exception.RecordFailurePredicate
      retry-exceptions: # 需要重试的异常
        - java.net.SocketTimeoutException
        - java.io.IOException
      ignore-exceptions: # 重试忽略的异常
          - io.github.robwin.exception.BusinessException

RecordFailurePredicate:

class RecordFailurePredicate : Predicate<Throwable> {

    /**
     * 判断是否需要重试
     *
     * @param t 异常
     * @return
     */
    override fun test(t: Throwable): Boolean {
        // 返回true --> 重试,返回false-->不重试
        return true
    }
}

使用:

@Retry(name = "backendA")

springboot项目如何简单整合Resilience4j

Resilience4j是一个针对Java 8和以上版本的轻量级容错库,它提供了一系列的容错功能,例如断路器、限流、重试等。这些功能可以帮助开发人员更好地保护应用程序免受故障、延迟和错误的影响。

在Spring Boot项目中整合Resilience4j非常方便,只需要添加相应的依赖,然后使用注解或者编程方式来配置并启用所需的Resilience4j功能即可。

添加依赖

1. 在pom.xml文件中添加以下依赖:

<dependency>
    <groupId>io.github.resilience4j</groupId>
    <artifactId>resilience4j-spring-boot2</artifactId>
    <version>1.7.0</version>
</dependency>

此外,还需要根据需要添加其他Resilience4j模块的依赖,例如resilience4j-circuitbreaker、resilience4j-retry等。

2. 配置Resilience4j功能

可以通过注解或者编程方式配置Resilience4j功能。

例如,要在应用程序中启用断路器功能,可以使用@CircuitBreaker注解进行配置:

@Service
public class MyService {
 
    @CircuitBreaker(name = "myService", fallbackMethod = "fallback")
    public String doSomething() {
        // ...
        代码逻辑
    }
 
    public String fallback(Throwable t) {
        // ...
       回调逻辑
    }
}
 
//在上面的示例中,
@CircuitBreaker注解将MyService.doSomething()方法标记为使用名

为myService的断路器功能,并指定了一个回退方法fallback()。

3. 启用Resilience4j功能

可以通过在Spring Boot配置文件中添加相应的属性来启用Resilience4j功能。

例如,在application.yml文件中添加以下属性可以启用Resilience4j的断路器功能(示例如下):

resilience4j:
  circuitbreaker:
    configs:
      default:
        registerHealthIndicator: true # 是否启用健康检查
        ringBufferSizeInClosedState: 5 # 断路器关闭时环形缓冲区大小
        ringBufferSizeInHalfOpenState: 3 # 断路器半开时环形缓冲区大小
        waitDurationInOpenState: 10s # 断路器打开后等待时间
        failureRateThreshold: 50 # 失败率阈值
        minimumNumberOfCalls: 10 # 最小请求数
        permittedNumberOfCallsInHalfOpenState: 3 # 断路器半开时允许的请求数
    instances:
      backendService:
        circuitBreakerConfig: default # 引用 default 已定义的配置
        registerHealthIndicator: true # 是否启用健康检查

4. 配置全局的异常处理器

如果要统一处理 Resilience4j 的异常的话,可以配置一个全局的异常处理器,将它们捕获并处理。

示例配置如下:

@ControllerAdvice
public class GlobalExceptionHandler {
    @ExceptionHandler(value = {
            CircuitBreakerOpenException.class,
            BulkheadFullException.class,
            RateLimiterFullException.class,
            RequestNotPermitted.class,
            RetryException.class
    })
    public ResponseEntity<Object> handleResilience4jExceptions(Exception ex) {
        // 处理 Resilience4j 异常
    }
}
 
//这里通过 @ControllerAdvice 注解声明了一个全局异常处理器,
并使用 @ExceptionHandler 注解指定要处理的 Resilience4j 异常。

此外,还可以通过编程方式启用Resilience4j功能。

例如,在Application类中添加以下代码可以自动检测并注册所有带有@CircuitBreaker注解的服务:

@EnableCircuitBreaker
@SpringBootApplication
public class Application {
    // ...
}

这就是在Spring Boot项目中整合Resilience4j的基本步骤。当然,还可以根据需要进行更详细的配置和定制。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Mybatis批量插入,返回主键ID不成功,巨坑记录

    Mybatis批量插入,返回主键ID不成功,巨坑记录

    这篇文章主要介绍了Mybatis批量插入,返回主键ID不成功,巨坑记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • mybatis使用@mapkey获取的结果的键(key)为null问题

    mybatis使用@mapkey获取的结果的键(key)为null问题

    这篇文章主要介绍了mybatis使用@mapkey获取的结果的键(key)为null问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • SpringBoot启动嵌入式Tomcat的实现步骤

    SpringBoot启动嵌入式Tomcat的实现步骤

    本文主要介绍了浅谈SpringBoot如何启动嵌入式Tomcat,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • Spring Cloud gateway 网关如何拦截Post请求日志

    Spring Cloud gateway 网关如何拦截Post请求日志

    这篇文章主要介绍了Spring Cloud gateway 网关如何拦截Post请求日志的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 浅谈java 单例模式DCL的缺陷及单例的正确写法

    浅谈java 单例模式DCL的缺陷及单例的正确写法

    这篇文章主要介绍了浅谈java 单例模式DCL的缺陷及单例的正确写法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Java利用MessageFormat实现短信模板的匹配

    Java利用MessageFormat实现短信模板的匹配

    这篇文章主要介绍了Java利用MessageFormat实现短信模板的匹配,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • Java简单工厂和工厂方法模式详细解析

    Java简单工厂和工厂方法模式详细解析

    这篇文章主要介绍了Java简单工厂和工厂方法模式详细解析,简单工厂模式属于类的创新型模式,又叫静态工厂方法模式是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类,需要的朋友可以参考下
    2023-12-12
  • java项目怎么集成stable diffusion图文生成算法

    java项目怎么集成stable diffusion图文生成算法

    在开发Java项目过程中,我们经常需要使用消息传递来实现不同组件之间的通信,Stable Diffusion是一种基于消息传递的实时通信解决方案,使用Java调用外部服务(如Python脚本或API服务),这些服务运行Stable Diffusion模型,本文将介绍如何将Stable Diffusion集成到Java项目
    2024-07-07
  • 关于weblogic部署Java项目的包冲突问题的解决

    关于weblogic部署Java项目的包冲突问题的解决

    这篇文章主要介绍了关于weblogic部署Java项目的包冲突问题的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • dubbo服务注册到nacos的过程剖析

    dubbo服务注册到nacos的过程剖析

    这篇文章主要为大家介绍了dubbo服务注册到nacos的过程剖析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职极限
    2022-02-02

最新评论