0

0

Python 幂等性设计的常见模式

舞夢輝影

舞夢輝影

发布时间:2026-02-16 12:53:03

|

393人浏览过

|

来源于php中文网

原创

幂等的核心是同一请求(带唯一标识)无论执行多少次,业务状态只变更一次;关键不在不报错,而在不产生副作用,需客户端生成幂等键、服务端校验、db事务内完成状态变更与幂等校验。

python 幂等性设计的常见模式

为什么 idempotent 不能只靠重试加 try/except

重试 + 捕获异常看似能防重复,但实际只是掩盖了状态不一致。比如支付接口被调两次,第一次成功扣款但网络超时没收到响应,第二次重试又扣了一次——这不是幂等,是资损。

真正幂等的核心是:**同一请求(带唯一标识)无论执行多少次,业务状态只变更一次**。关键不在“不报错”,而在“不产生副作用”。

  • 必须把幂等键(如 idempotency_key)作为业务逻辑入口参数,不是日志或中间件里偷偷记一笔
  • 幂等键要由客户端生成(如 UUID),服务端只校验、不生成——否则分布式下无法保证跨请求一致性
  • 存储校验点必须和业务更新在同一个事务里(如 PostgreSQL 的 INSERT ... ON CONFLICT DO NOTHING),否则存在竞态窗口

用数据库唯一约束实现最简幂等(Python + SQLAlchemy)

这是中小系统最稳的起点,不依赖外部组件,靠 DB 原子性兜底。重点不是“怎么写 ORM”,而是怎么设计约束字段和事务边界。

常见错误:只在业务表加唯一索引,但没把幂等键和业务主键组合建索引,导致插入时冲突判断失效。

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

magento(麦进斗)
magento(麦进斗)

Magento是一套专业开源的PHP电子商务系统。Magento设计得非常灵活,具有模块化架构体系和丰富的功能。易于与第三方应用系统无缝集成。Magento开源网店系统的特点主要分以下几大类,网站管理促销和工具国际化支持SEO搜索引擎优化结账方式运输快递支付方式客户服务用户帐户目录管理目录浏览产品展示分析和报表Magento 1.6 主要包含以下新特性:•持久性购物 - 为不同的

下载
  • 幂等键字段类型建议用 CHAR(32)(存 UUID)或 TEXT,避免截断;不要用 VARCHAR 加长度限制后隐式截断
  • 唯一约束必须包含 idempotency_key 和业务关键状态字段(如 order_id + status),否则无法区分“同一订单不同操作”
  • SQLAlchemy 中用 session.execute(text("INSERT INTO ... ON CONFLICT DO NOTHING"))merge() 更可控——后者可能触发无意义 UPDATE

Django 视图层如何安全接入幂等头(Idempotency-Key

Django 默认不解析这个 header,直接读 request.META.get("HTTP_IDEMPOTENCY_KEY") 就行,但坑在后续链路怎么传、怎么验。

典型翻车:视图里取到 key 后,把它当普通参数传给异步任务(如 Celery),结果任务重试时 key 丢了,或者多个任务并发写同一 key 没锁住。

  • 必须在视图函数开头就校验 key 是否为空或格式非法(如非 UUID),空值直接 return HttpResponse(400),别往后传
  • 如果走异步,key 必须作为任务参数显式传递,且任务函数开头立刻做幂等检查——Celery 的 retry 不会自动带原始 header
  • 不要用 Django cache(如 Redis)单独存 key 状态,除非你同时用 Lua 脚本保证 set+check 原子性;否则 getset 之间有竞态

Redis 实现高性能幂等(SET key value EX 3600 NX)的三个硬限制

Redis 快,但不是万能解药。它适合“纯校验型”幂等(如发短信、发通知),不适合“需回滚”的业务(如库存预占)。

错误用法:用 INCR 计数然后判断是否 >1——这无法防止并发写入,两个请求几乎同时 INCR 都返回 1。

  • 必须用 SET key value EX 3600 NXNX 是关键),value 建议存请求摘要(如 hashlib.sha256(body.encode()).hexdigest()),用于事后审计
  • 过期时间不能拍脑袋定:要大于最长业务耗时(含下游超时重试),但也不能太长(如 7 天),否则 key 泛滥,Redis 内存扛不住
  • Redis 故障时必须降级策略——比如切到本地内存缓存(lru_cache)或直接拒绝(503 Service Unavailable),绝不能静默跳过幂等检查
事情说清了就结束。幂等不是加个装饰器的事,它是请求生命周期里每个环节对“同一性”的共同承诺。最容易被忽略的,是下游服务(比如发券、调第三方 API)自己有没有幂等能力——你这边拦住了,它那边重复执行,照样出问题。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Python Web 框架 Django 深度开发
Python Web 框架 Django 深度开发

本专题系统讲解 Python Django 框架的核心功能与进阶开发技巧,包括 Django 项目结构、数据库模型与迁移、视图与模板渲染、表单与认证管理、RESTful API 开发、Django 中间件与缓存优化、部署与性能调优。通过实战案例,帮助学习者掌握 使用 Django 快速构建功能全面的 Web 应用与全栈开发能力。

61

2026.02.04

什么是分布式
什么是分布式

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

391

2023.08.11

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

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

246

2023.10.07

什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

180

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

222

2025.12.18

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

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

325

2023.10.17

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

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

772

2023.10.18

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

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

96

2025.08.19

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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