熔断器(Hystrix,Resilience4j)
熔断器
核心原理
熔断器通过监控服务调用失败率,在达到阈值时自动切断请求,进入熔断状态(类似电路保险丝)。其核心流程为:
关闭状态(Closed):正常处理请求,统计失败率。
打开状态(Open):触发熔断,直接拒绝请求,调用降级逻辑。
半开状态(Half-Open):允许少量请求尝试恢复,若成功则关闭熔断。
状态流转
- 关闭状态(Closed)
行为:熔断器关闭,所有请求正常通过。
触发条件:
初始默认状态。
从半开状态恢复成功后切换至此状态。
核心规则:
统计时间窗口内的请求失败率。
当失败率超过阈值(如 50%)时,熔断器跳转到 打开状态。
# Resilience4j 配置(失败率 ≥ 50% 触发熔断)
resilience4j.circuitbreaker:instances:serviceA:failureRateThreshold: 50minimumNumberOfCalls: 5 # 最少需要5次调用才计算失败率slidingWindowSize: 10 # 统计最近10次调用
- 打开状态(Open)
行为:熔断器打开,所有请求被快速拒绝,直接触发降级逻辑。
触发条件:
关闭状态下失败率超过阈值。
核心规则:
熔断器保持打开状态一段时间(如 10秒)。
超时后自动进入 半开状态。 - 半开状态(Half-Open)
行为:允许少量探测请求通过,若成功则恢复服务,否则重新熔断。
触发条件:
熔断器从打开状态等待指定时间后自动切换。
核心规则:
允许有限数量的请求(如 3次)试探性调用。
若成功率达标(如 80%),则关闭熔断器。
若失败率仍高,则重新进入 打开状态。
# Resilience4j 半开状态配置
resilience4j.circuitbreaker:instances:serviceA:permittedNumberOfCallsInHalfOpenState: 3 # 允许3次探测请求failureRateThreshold: 20 # 半开状态下失败率≥20%则重新熔断waitDurationInOpenState: 10s # 打开状态持续10秒后进入半开
Hystrix使用
依赖
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId><version>2.2.10.RELEASE</version> <!-- 对应 Spring Cloud Hoxton.SR12 -->
</dependency>
启用 Hystrix
@SpringBootApplication
@EnableHystrix // 启用 Hystrix
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
全局默认配置
hystrix:command:default:execution:isolation:strategy: THREAD # 隔离策略(THREAD 或 SEMAPHORE)thread:timeoutInMilliseconds: 2000 # 超时时间(默认1秒)circuitBreaker:enabled: true # 是否启用熔断requestVolumeThreshold: 5 # 触发熔断的最小请求数errorThresholdPercentage: 50 # 失败率阈值(%)sleepWindowInMilliseconds: 10000 # 熔断持续时间(ms)threadpool:default:coreSize: 10 # 线程池核心线程数maxQueueSize: 100 # 最大队列容量(-1表示禁用队列)queueSizeRejectionThreshold: 20 # 队列拒绝阈值
使用示例
基础熔断与降级
@Service
public class UserService {@HystrixCommand(fallbackMethod = "getUserFallback",commandProperties = {// 自定义熔断规则(覆盖全局配置)@HystrixProperty(name = "circuitBreaker.requestVolumeThreshold", value = "3"),@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds", value = "5000")})public String getUser(String userId) {if ("error".equals(userId)) {throw new RuntimeException("模拟服务失败");}return "User:" + userId;}// 降级方法(参数必须与原方法一致)public String getUserFallback(String userId) {return "Fallback User:" + userId;}
}
异步调用
@HystrixCommand(fallbackMethod = "asyncFallback")
public Future<String> asyncGetUser(String userId) {return new AsyncResult<String>() {@Overridepublic String invoke() {return "Async User:" + userId;}};
}public String asyncFallback(String userId) {return "Async Fallback:" + userId;
}
忽略特定异常
@HystrixCommand(fallbackMethod = "validateFallback",ignoreExceptions = { IllegalArgumentException.class } # 此异常不触发熔断
)
public String validate(String input) {if (input.isEmpty()) {throw new IllegalArgumentException("输入为空");}return "Valid:" + input;
}
Hystrix+Feign Client 实现熔断
- 启用 Hystrix 和 Feign
@SpringBootApplication
@EnableFeignClients // 启用 Feign Client
@EnableHystrix // 启用 Hystrix
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
- 定义 Feign 接口及降级类
// Feign Client 接口
@FeignClient(name = "user-service",url = "http://localhost:8081",fallback = UserServiceFallback.class // 指定降级类
)
public interface UserServiceClient {@GetMapping("/users/{userId}")User getUser(@PathVariable String userId);
}// 降级类实现 Feign 接口
@Component
public class UserServiceFallback implements UserServiceClient {@Overridepublic User getUser(String userId) {return new User(userId, "Fallback User");}
}
- 配置熔断参数 (application.yml)
feign:hystrix:enabled: true # 启用 Hystrix 支持(默认 true,可省略)hystrix:command:default:circuitBreaker:requestVolumeThreshold: 5 # 触发熔断的最小请求数errorThresholdPercentage: 50 # 失败率阈值(%)sleepWindowInMilliseconds: 10000 # 熔断持续时间(ms)execution:isolation:thread:timeoutInMilliseconds: 3000 # 超时时间
- 禁用 Hystrix 对特定 Feign Client
@FeignClient(name = "order-service",url = "http://localhost:8082",configuration = FeignDisableHystrixConfig.class
)
public interface OrderServiceClient { ... }// 自定义配置类
public class FeignDisableHystrixConfig {@Beanpublic Feign.Builder feignBuilder() {return Feign.builder(); // 不使用 Hystrix}
}
注意
- Hystrix 熔断器在 打开状态(Open) 后,默认经过 5秒 进入 半开状态(Half-Open)
可以通过 circuitBreaker.sleepWindowInMilliseconds 参数调整等待时间。
@HystrixCommand(commandProperties = {@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds", value = "10000" // 10秒后进入半开状态)}
)
public String callService() { ... }
- Hystrix 的半开状态逻辑是固定不可配置的(Resilience4j可以进行配置),其行为如下:
探测请求数量:仅允许 1次 请求通过。
熔断关闭条件:
如果探测请求 成功,熔断器关闭,恢复服务。
如果探测请求 失败,熔断器重新打开,继续等待下一个 sleepWindowInMilliseconds 周期。
Resilience4j使用
依赖
<!-- Resilience4j 核心模块 -->
<dependency><groupId>io.github.resilience4j</groupId><artifactId>resilience4j-spring-boot2</artifactId><version>1.7.1</version>
</dependency>
<!-- 支持注解方式(需 Spring AOP) -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId>
</dependency>
使用示例
熔断器
- 配置
resilience4j:circuitbreaker:instances:userService:failureRateThreshold: 50 # 失败率阈值(%)minimumNumberOfCalls: 5 # 触发统计的最小请求数slidingWindowType: COUNT_BASED # 滑动窗口类型slidingWindowSize: 10 # 窗口大小(次数)waitDurationInOpenState: 10s # 熔断持续时间permittedNumberOfCallsInHalfOpenState: 3 # 半开状态允许的请求数ignoreExceptions: # 忽略特定异常(不触发熔断)- com.example.BusinessException
- 代码
@Service
public class UserService {@CircuitBreaker(name = "userService", fallbackMethod = "getUserFallback")public User getUser(String userId) {if (userId == null) {throw new RuntimeException("Invalid User ID");}return new User(userId, "Active");}// 降级方法(参数需一致,可添加异常参数)public User getUserFallback(String userId, Exception ex) {return new User(userId, "Fallback");}
}
Resilience4j+Feign Client 实现熔断
- 配置
resilience4j:circuitbreaker:instances:userService: # 熔断器实例名(需与 Feign Client 名称对应)failureRateThreshold: 50 # 失败率阈值(%)minimumNumberOfCalls: 5 # 触发统计的最小请求数slidingWindowType: COUNT_BASED # 滑动窗口类型slidingWindowSize: 10 # 窗口大小(次数)waitDurationInOpenState: 10s # 熔断持续时间permittedNumberOfCallsInHalfOpenState: 3 # 半开状态允许的请求数recordExceptions: # 触发熔断的异常类型- java.io.IOException- java.util.concurrent.TimeoutException
- 代码
@FeignClient(name = "userService", // 与熔断器实例名一致url = "http://localhost:8081",fallback = UserServiceFallback.class // 直接指定降级类
)
public interface UserServiceClient {@GetMapping("/users/{userId}")User getUser(@PathVariable String userId);
}
- 熔断降级类
@Component
public class UserServiceFallback implements UserServiceClient {@Overridepublic User getUser(String userId) {// 熔断降级逻辑return new User(userId, "Fallback User");}
}
- 在降级方法中捕获异常
@Component
public class UserServiceFallback implements UserServiceClient {@Overridepublic User getUser(String userId, Throwable ex) { // 添加 Throwable 参数log.error("Fallback triggered by: {}", ex.getMessage());return new User(userId, "Fallback User");}
}
重试(Retry)
- 配置
resilience4j:retry:instances:paymentService:maxAttempts: 3 # 最大重试次数waitDuration: 500ms # 重试间隔retryExceptions: # 触发重试的异常类型- java.io.IOException
- 代码
@Service
public class PaymentService {@Retry(name = "paymentService", fallbackMethod = "processPaymentFallback")public String processPayment(String orderId) {if (Math.random() > 0.3) {throw new IOException("Payment Gateway Error");}return "Payment Success: " + orderId;}public String processPaymentFallback(String orderId, Exception ex) {return "Fallback: " + orderId;}
}
限流(Rate Limiter)
限制单位时间内的请求速率:通过 令牌桶算法 或 漏桶算法,控制请求的流量。
实现方式:
令牌桶算法:以固定速率生成令牌,请求需获取令牌才能执行。
漏桶算法:强制请求以恒定速率执行,平滑处理突发流量。
- 配置
resilience4j:ratelimiter:instances:orderService:limitForPeriod: 5 # 时间窗口内允许的请求数limitRefreshPeriod: 1s # 时间窗口长度timeoutDuration: 100ms # 等待令牌的超时时间
- 代码
@Service
public class OrderService {@RateLimiter(name = "orderService", fallbackMethod = "createOrderFallback")public String createOrder(String productId) {return "Order Created: " + productId;}public String createOrderFallback(String productId, Exception ex) {return "Too Many Requests: " + productId;}
}
隔板(Bulkhead)
限制同一时间的最大并发请求数:通过控制 并发执行数量,防止资源耗尽
- 隔板的两种实现
信号量隔离(SemaphoreBulkhead)
原理:基于信号量(Semaphore)控制并发请求的最大数量。
行为:当并发请求数超过阈值时,立即拒绝新请求(抛出BulkheadFullException),无等待队列。
适用场景:轻量级、低延迟的并发控制,适用于I/O密集型或快速响应的操作。
线程池隔离(FixedThreadPoolBulkhead,已弃用)
原理:通过有界线程池和任务队列限制并发(类似Hystrix的线程隔离)。
行为:任务提交到线程池执行,队列满时拒绝新任务。
状态:Resilience4j官方已弃用此实现,推荐使用信号量隔离或结合其他异步库(如CompletableFuture)管理线程资源。 - 配置
resilience4j:bulkhead:instances:reportService:maxConcurrentCalls: 10 # 最大并发调用数maxWaitDuration: 10ms # 等待进入隔板的超时时间
maxWaitDuration:
当隔板的并发请求数已满(达到 maxConcurrentCalls 限制)时,新请求可以等待其他请求释放资源的最大时间。
默认值:0(即不等待,直接拒绝请求,抛出 BulkheadFullException)。
单位:毫秒(例如 Duration.ofSeconds(2) 表示最多等待 2 秒)。
- 代码
@Service
public class ReportService {@Bulkhead(name = "reportService", fallbackMethod = "generateReportFallback")public String generateReport(String reportId) {return "Report: " + reportId;}public String generateReportFallback(String reportId, Exception ex) {return "System Busy: " + reportId;}
}
组合使用多个容错机制
@Service
public class ProductService {// 同时应用熔断 + 重试 + 限流@CircuitBreaker(name = "productService", fallbackMethod = "fallback")@Retry(name = "productService", fallbackMethod = "fallback")@RateLimiter(name = "productService", fallbackMethod = "fallback")public String getProduct(String productId) {if (Math.random() > 0.5) {throw new RuntimeException("Service Error");}return "Product: " + productId;}public String fallback(String productId, Exception ex) {return "Fallback: " + productId;}
}
Hystrix vs Resilience4j
- 核心特性对比
- 功能深度对比
熔断器
容错模式
- 性能对比
资源消耗
Hystrix:线程池隔离需要为每个服务分配独立线程池,线程上下文切换开销大,适合资源充足的中型系统。
Resilience4j:信号量隔离无需创建线程,内存占用低,适合高并发场景和云原生环境。
吞吐量测试
场景:1000并发请求,熔断触发条件相同。
结果:
Resilience4j 吞吐量比 Hystrix 高 30%~50%。
Resilience4j 的 GC 停顿时间更短。
相关文章:

熔断器(Hystrix,Resilience4j)
熔断器 核心原理 熔断器通过监控服务调用失败率,在达到阈值时自动切断请求,进入熔断状态(类似电路保险丝)。其核心流程为: 关闭状态(Closed):正常处理请求,统计失…...
贪心算法套路模板+详细适用场景+经典题目清单
1. 排序 贪心选择 适用场景: 任务调度问题:需要安排多个任务,尽量完成更多任务或最小冲突。 区间调度问题:选出最多互不重叠的区间。 区间覆盖问题:用最少区间覆盖某个范围。 合并区间问题:合并重叠区…...

C++23 容器从其他兼容范围的可构造性与可赋值性 (P1206R7)
文章目录 背景与动机提案内容与实现细节提案 P1206R7实现细节编译器支持 对开发者的影响提高灵活性简化代码向后兼容性 总结 C23标准引入了对容器构造和赋值的新特性,这些特性使得容器能够更灵活地从其他兼容范围初始化,并支持从范围赋值。这些改进由提案…...

多通道振弦式数据采集仪MCU安装指南
设备介绍 数据采集仪 MCU集传统数据采集器与5G/4G,LoRa/RS485两种通信功能与一体的智能数据采集仪。该产品提供振弦、RS-485等的物理接口,能自动采集并存储多种自然资源、建筑、桥梁、城市管廊、大坝、隧道、水利、气象传感器的实时数据,利用现场采集的数…...
Axios中POST、PUT、PATCH用法区别
在 Axios 中,POST、PUT 和 PATCH 是用于发送 HTTP 请求的三种不同方法,它们的核心区别源自 HTTP 协议的设计语义。以下是它们的用法和区别: 1. POST 语义:用于创建新资源。 特点: 非幂等(多次调用可能产生…...
synchronized 实现原理
1. 对象头与 Mark Word 每个 Java 对象在内存中分为三部分:对象头、实例数据 和 对齐填充。 对象头 是核心部分,包含以下信息: Mark Word(标记字段):存储对象的哈希码、分代年龄、锁状态等。Klass Pointe…...

SOC-ESP32S3部分:9-GPIO输入按键状态读取
飞书文档https://x509p6c8to.feishu.cn/wiki/L6IGwHKV6ikQ08kqwAwcAvhznBc 前面我们学习了GPIO的输出,GPIO输入部分其实也是一样的,这里我们使用按键作为GPIO输入例程讲解,分三步走。 查看板卡原理图,确定使用的是哪个GPIO查看G…...
前端(小程序)学习笔记(CLASS 2):WXML模板语法与WXSS模板样式
1、数据绑定 数据绑定的基本原则 1、在data中定义数据 在页面对应的.js文件中,把数据定义到data对象中即可: Page({data: {//字符串类型的数据info: init data,//数组类型的数据msgList: [{msg: hello}, {msg: world}]} }) 2、在WXML中使用数据(Mus…...

Ubuntu20.04的安装(VMware)
1.Ubuntu20.04.iso文件下载 下载网址:ubuntu-releases-20.04安装包下载_开源镜像站-阿里云 2.创建虚拟环境 2.1打开VMware与创建新虚拟机 点击创建新虚拟机 如果没下好可以点击稍后安装操作系统 选择linux版本选择Ubuntu 64位然后点击下一步。 注意这里需要选择一…...

【论文阅读】LLaVA-OneVision: Easy Visual Task Transfer
LLaVA-OneVision: Easy Visual Task Transfer 原文摘要 研究背景与目标 开发动机: 基于LLaVA-NeXT博客系列对数据、模型和视觉表征的探索,团队整合经验开发了开源大型多模态模型 LLaVA-OneVision。 核心目标: 突破现有开源LMM的局限…...

Spring Boot 项目多数据源配置【dynamic datasource】
前言: 随着互联网的发展,数据库的读写分离、数据迁移、多系统数据访问等多数据源的需求越来越多,我们在日常项目开发中,也不可避免的为了解决这个问题,本篇来分享一下在 Spring Boot 项目中使用多数据源访问不通的数据…...

JAVA查漏补缺(2)
AJAX 什么是Ajax Ajax(Asynchronous Javascript And XML),即是异步的JavaScript和XML,Ajax其实就是浏览器与服务器之间的一种异步通信方式 异步的JavaScript 它可以异步地向服务器发送请求,在等待响应的过程中&…...

【Web前端】JavaScript入门与基础(二)
Javascript对象 什么是对象?对象(object)是 JavaScript 语言的核心概念,也是最重要的数据类型。简单说,对象就是一组“键值对”(key-value)的集合,是一种无序的复合数据集合。 var…...
取消 Conda 默认进入 Base 环境
在安装 Conda 后,每次打开终端时默认会进入 base 环境。可以通过以下方法取消这一默认设置。 方法一:使用命令行修改配置 在终端中输入以下命令,将 auto_activate_base 参数设置为 false: conda config --set auto_activate_ba…...

Electron+vite+vue3 从0到1搭建项目,开发Win、Mac客户端
随着前端技术的发展,出现了所谓的大前端。 大前端则是指基于前端技术延伸出来的各种终端平台及应用场景,包括APP、桌面端、手表终端、服务端等。 本篇文章主要是和大家一起学习一下使用Electron 如何打包出 Windows 和 Mac 所使用的客户端APPÿ…...
《深度揭秘:解锁智能体大模型自我知识盲区探测》
当面对超出其训练数据边界和固有知识范畴的问题时,智能体大模型往往会陷入困境,却浑然不知,这便是知识盲区带来的隐患。如何构建能够自动发现自身知识盲区的智能体大模型,成为当下人工智能领域亟待攻克的前沿难题,它关…...
打卡Day33
简单的神经网络 数据的准备 # 仍然用4特征,3分类的鸢尾花数据集作为我们今天的数据集 from sklearn.datasets import load_iris from sklearn.model_selection import train_test_split import numpy as np# 加载鸢尾花数据集 iris load_iris() X iris.data # …...
计算机组成原理-基本运算部件定点数的运算
2.2基本运算部件 整理自up主beokayy_ 1.加法器 一位全加器 全加器是最基本的加法单元: 三个输入端:加数Ai,加数Bi,低位传进来的进位C1-1两个输出端:本位和S,向高位的进位C 全加器的逻辑表达式: SiAi⊕Bi⊕Ci-1CiAiBi(Ai⊕Bi)C…...

python打卡day34@浙大疏锦行
知识点回归: CPU性能的查看:看架构代际、核心数、线程数GPU性能的查看:看显存、看级别、看架构代际GPU训练的方法:数据和模型移动到GPU device上类的call方法:为什么定义前向传播时可以直接写作self.fc1(x) ①CPU性能查…...

SOC-ESP32S3部分:8-GPIO输出LED控制
飞书文档https://x509p6c8to.feishu.cn/wiki/OSQWwh95niobqUkKyDQcVgsbnFg 这节课,我们将会以ESP32S3外设GPIO的使用为例,带大家学习如何从零开始学会ESP32外设的使用。 例如,这节课我们的需求是,需要通过GPIO控制指示灯的亮灭&…...

05算法学习_59. 螺旋矩阵 II
05算法学习_59. 螺旋矩阵 II 05算法学习_59. 螺旋矩阵 II题目描述:个人代码:学习思路:第一种写法:题解关键点: 个人学习时疑惑点解答: 05算法学习_59. 螺旋矩阵 II 力扣题目链接: 59. 螺旋矩阵 II 题目描…...
绘制音频信号的各种频谱图,包括Mel频谱图、STFT频谱图等。它不仅能够绘制频谱图librosa.display.specshow
librosa.display.specshow 是一个非常方便的函数,用于绘制音频信号的各种频谱图,包括Mel频谱图、STFT频谱图等。它不仅能够绘制频谱图,还能自动设置轴标签和刻度,使得生成的图像更加直观和易于理解。 ### 函数签名 python libros…...

Linux `>`/`>>` 重定向操作符深度解析与高阶应用指南
Linux `>`/`>>` 重定向操作符深度解析与高阶应用指南 一、核心功能解析1. 基础重定向2. 标准流描述符二、高阶重定向技巧1. 多流重定向2. 文件描述符操作3. 特殊设备操作三、企业级应用场景1. 日志管理系统2. 数据管道处理3. 自动化运维四、安全与权限管理1. 防误操作…...

【自定义类型-联合和枚举】--联合体类型,联合体大小的计算,枚举类型,枚举类型的使用
目录 一.联合体类型 1.1--联合体类型的声明 1.2--联合体的特点 1.3--相同成员的结构体和联合体对比 1.4--联合体大小的计算 1.5--联合体练习 二.枚举类型 2.1--枚举类型的声明 2.2--枚举类型的优点 2.3--枚举类型的使用 🔥个人主页:草莓熊Lotso…...

李宏毅《深度学习》:Self-attention 自注意力机制
一,问题分析: 什么情况下需要使用self-attention架构,或者说什么问题是CNN等经典网络架构解决不了的问题,我们需要开发新的网络架构? 要解决什么问题《——》对应开发self-attention架构的目的? 1&#…...

C++初阶-list的使用1
目录 1.std::list简介 2.成员函数 2.1构造函数的使用 2.2list::operator的使用 3.迭代器 4.容量 4.1list::empty函数的使用 4.2list::size函数的使用 4.3list::max_size函数的使用 5.元素访问 6.修饰符 6.1list::assign函数的使用 6.2push_back和pop_back和push_fr…...
Linux中的tty与login之间的关系
agetty 进程和 login 进程之间的关系: 一、简要概括 agetty 是登录前的终端初始化程序。 login 是处理用户登录认证的程序。 关系:agetty 启动后等待用户输入用户名,然后调用 login 进程进行用户认证。 二、详细过程 1. agetty 的作用 a…...

Python web 开发 Flask HTTP 服务
Flask 是一个轻量级的 Web 应用框架,它基于 Python 编写,特别适合构建简单的 Web 应用和 RESTful API。Flask 的设计理念是提供尽可能少的约定和配置,从而让开发者能够灵活地构建自己的 Web 应用。 https://andi.cn/page/622189.html...

分享|16个含源码和数据集的计算机视觉实战项目
本文将分享16个含源码和数据集的计算机视觉实战项目。具体包括: 1. 人数统计工具 2. 颜色检测 3. 视频中的对象跟踪 4. 行人检测 5. 手势识别 6. 人类情感识别 7. 车道线检测 8. 名片扫描仪 9. 车牌识别 10. 手写数字识别 11.鸢尾花分类 12. 家庭照片人脸检测 13. 乐…...

二十三、面向对象底层逻辑-BeanDefinitionParser接口设计哲学
一、引言:Spring XML配置的可扩展性基石 在Spring框架的演进历程中,XML配置曾长期作为定义Bean的核心方式。虽然现代Spring应用更倾向于使用注解和Java Config,但在集成第三方组件、兼容遗留系统或实现复杂配置逻辑的场景下,XML配…...