0

0

Python如何做限流熔断_容错机制

冷炫風刃

冷炫風刃

发布时间:2026-03-10 11:12:10

|

121人浏览过

|

来源于php中文网

原创

python实现限流、熔断和容错的核心是控制请求速率、快速失败异常依赖、自动恢复故障服务;常用方案为slowapi限流、circuitbreaker熔断、tenacity重试,并需监控与组合使用。

python如何做限流熔断_容错机制

Python 实现限流、熔断和容错机制,核心是控制请求速率、快速失败异常依赖、自动恢复故障服务。不靠框架也能做,但推荐用成熟库降低出错风险。

限流(Rate Limiting)

防止突发流量压垮服务,常见策略有令牌桶、漏桶、固定窗口、滑动窗口。

  • 使用 slowapi(基于 Starlette/FastAPI):适合 Web 接口,支持按 IP、用户、路径等维度限流,配置简单。
    示例:@limiter.limit("5/minute") 即每分钟最多 5 次请求。
  • redis + redis-py 自研滑动窗口:适合分布式场景。用 Redis 的 ZSET 记录时间戳,每次请求前 zremrangebyscore 清理过期记录,再 zcard 统计当前请求数。
  • 单机轻量选 ratelimit:基于内存或 threading.local,适合脚本或非并发服务,不跨进程共享状态。

熔断(Circuit Breaker)

当下游服务连续失败达到阈值,自动跳过调用,避免雪崩,一段时间后试探性恢复。

MemFree
MemFree

MemFree - 来自知识库和互联网的混合AI搜索,更快获取准确答案

下载
  • pydantic-settings + circuitbreaker 是经典组合。装饰器方式接入,定义失败次数、超时时间、重置周期。
    例如:@circuit(failure_threshold=5, timeout_duration=60) 表示 5 次失败后熔断 60 秒。
  • 注意熔断状态需线程安全。默认 circuitbreaker 库用 threading.Lock 保护,高并发下可考虑升级为 threading.RLock 或改用 aiocircuit(异步友好)。
  • 熔断打开时,建议返回兜底数据(如缓存旧值)或明确错误(CircuitBreakerError),前端/调用方据此降级展示。

容错与重试(Fault Tolerance & Retry)

网络抖动、临时超时很常见,合理重试 + 退避策略能显著提升成功率。

立即学习Python免费学习笔记(深入)”;

  • tenacity 是最灵活的重试库:支持按异常类型、返回值、耗时等条件触发重试,内置指数退避、jitter 防止重试风暴。
    示例:失败时等待 1s→2s→4s,最多 3 次,且只重试 requests.TimeoutConnectionError
  • 重试要配合熔断——比如某接口连续重试 3 次都失败,就该触发熔断,而不是无限重试。
  • 写数据库类操作慎用重试(可能重复写入),应优先用幂等设计(如带唯一业务 ID 的 upsert)。

组合使用建议

真实服务中三者常嵌套使用:先限流控入口 → 调用外部服务时加熔断 → 熔断关闭状态下用 tenacity 控制重试行为。

  • FastAPI 项目推荐栈:slowapi(限流) + circuitbreaker(同步熔断)或 aiocircuit(异步) + tenacity(重试)。
  • 微服务间调用,可在 HTTP client 层统一封装(如自定义 requests.Session 子类,内置限流器和熔断器)。
  • 所有策略都要配监控:记录被限流数、熔断开关事件、重试次数。可用 Prometheus + Grafana 可视化关键指标。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

250

2023.10.07

Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API

Python FastAPI 异步开发利用 async/await 关键字,通过定义异步视图函数、使用异步数据库库 (如 databases)、异步 HTTP 客户端 (如 httpx),并结合后台任务队列(如 Celery)和异步依赖项,实现高效的 I/O 密集型 API,显著提升吞吐量和响应速度,尤其适用于处理数据库查询、网络请求等耗时操作,无需阻塞主线程。

28

2025.12.22

Python 微服务架构与 FastAPI 框架
Python 微服务架构与 FastAPI 框架

本专题系统讲解 Python 微服务架构设计与 FastAPI 框架应用,涵盖 FastAPI 的快速开发、路由与依赖注入、数据模型验证、API 文档自动生成、OAuth2 与 JWT 身份验证、异步支持、部署与扩展等。通过实际案例,帮助学习者掌握 使用 FastAPI 构建高效、可扩展的微服务应用,提高服务响应速度与系统可维护性。

251

2026.02.06

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

334

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

775

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1878

2023.10.19

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号