resilience4j的circuitbeaker,bulkheader,ratelimiter,retry的使用

本文主要是介绍resilience4j的circuitbeaker,bulkheader,ratelimiter,retry的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

resilience4j是提供服务熔断,降级,限流,重试等能力的微服务组件。在hystrix不再维护之后,目前作为前者的替代品。也是目前官方所主推的组件。其相对于hystrix更轻量级,没有复杂的依赖。其提供的能力比hystrix更强。其函数式风格的api能写出很简洁的代码。也有和spring-boot整合,能通过简单的注解和配置来集成其能力。其主要组件主要为**circuitbeaker(断路器),bulkheader(挡板),ratelimiter(限流器),retry(重试)**各个组件状态的变更都内置了事件接口。可以针对其事件做一个处理。

1.circuitbeaker(断路器)

断路器:在微服务技术中扮演则重要的角色,其主要作用是检测服务的异常次数,在达到阈值后会打开断路器,进行服务降级。避免拖垮整个服务。再后续一段时间后,又会放出一部分流量,看调用是否正常再决定关闭断路器。状态的转换图如下(图片来自官网)
在这里插入图片描述
关闭状态,打开状态,半开状态,3者的状态根据调用统计的结果相互转换

调用次数结果的存贮基于滑动窗口算法。
circuitbreaker提供了2种滑动窗口算法,一种基于有限窗口的总次数,(例如窗口的大小为10,就统计最近10次的调用结果来进行状态的转换),另一种基于时间的窗口算法。例如窗口是10,则可把最近10秒看做10个桶子,每个桶子保留当前那秒对应的所有调用结果,根据所有桶内的调用结果来进行状态的转换

1.1 circuitBeaker api的使用

CircuitBeakerRegistry:单个registry实例,可配置CircuitBreakerConfig,用户可根据自己想选择的Config类来生成对应的circuitBreaker实例。
主要属性如下

配置属性默认值描述
failureRateThreshold50失败率,调用失败达到该阈值,断路器会被打开,默认为50%
permittedNumberOfCalls
InHalfOpenState10半开状态下,能提供的凭证(即能通过的调用)
slidingWindowTypeCOUNT_BASED滑动窗口类型,默认为累计计数
slidingWindowSize100滑动窗口大小
minimumNumberOfCalls100每个滑块周期内,至少要满足多少调用次数,否则即使达到了错误率,也不会进行状态的变更
recordExceptionsempty该被纳入错误率计算的异常,默认为空
ignoreExceptionsempty不该被纳入错误率计算的异常,默认为空
recordFailurePredicatethrowable -> true异常预测类,默认异常都为true,即都该被纳入错误率
ignoreExceptionPredicatethrowable -> false异常忽略预测类,默认异常都为false,即都不该纳入错误率

其余详细配置,其移步官方文档
https://resilience4j.readme.io/docs/circuitbreaker
示例代码如下
如果是maven项目,需引入相关依赖,由于我使用的是spring-boot所以直接引入spring-boot的resilience4j

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

原生api的使用

package com.ly;import io.github.resilience4j.bulkhead.Bulkhead;
import io.github.resilience4j.bulkhead.BulkheadConfig;
import io.github.resilience4j.bulkhead.ThreadPoolBulkhead;
import io.github.resilience4j.bulkhead.ThreadPoolBulkheadConfig;
import io.github.resilience4j.circuitbreaker.CircuitBreaker;
import io.github.resilience4j.circuitbreaker.CircuitBreakerConfig;
import io.github.resilience4j.circuitbreaker.CircuitBreakerRegistry;
import io.github.resilience4j.ratelimiter.RateLimiter;
import io.github.resilience4j.ratelimiter.RateLimiterConfig;
import io.github.resilience4j.retry.Retry;
import io.github.resilience4j.retry.RetryConfig;
import io.vavr.control.Try;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;import java.time.Duration;
import java.util

这篇关于resilience4j的circuitbeaker,bulkheader,ratelimiter,retry的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/274373

相关文章

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数