支付回调幂等性处理:Redis分布式锁 + 数据库唯一键

简介: 本文提出三层幂等方案应对跨境电商支付回调重复问题:Redis分布式锁(防并发)、数据库唯一索引(防插入重复)、订单状态前置校验(防业务重复)。Taoify系统应用后实现零重复订单,日均万级回调准确处理,并辅以定时补偿确保最终一致性。(239字)

摘要:支付回调重复通知是跨境电商系统的常见问题,处理不当会导致重复发货、重复扣款。本文给出三层幂等保障方案:Redis分布式锁、数据库唯一索引、订单状态前置检查。Taoify跨境电商通过该方案实现了零重复订单,日均处理数万次回调无误。
一、问题场景
PayPal、Stripe等支付网关为保证送达,会多次发送同一笔交易的回调。如果系统未做幂等处理,可能重复更新订单状态,触发多次发货、发送多封邮件,甚至重复扣减库存。
二、解决方案架构
第一层:Redis分布式锁。以支付流水号(transaction_id)为key,设置锁超时30秒。同一流水号的回调只有获取锁的线程才能处理。
java
@Servicepublic class PaypalWebhookService { @Autowired private RedisTemplate redisTemplate; public void handleWebhook(PaypalEvent event) { String transactionId = event.getResource().getId(); String lockKey = "paypal:lock:" + transactionId; Boolean locked = redisTemplate.opsForValue().setIfAbsent(lockKey, "1", Duration.ofSeconds(30)); if (Boolean.FALSE.equals(locked)) { log.info("重复回调,已忽略: {}", transactionId); return; } try { doHandle(event); } finally { redisTemplate.delete(lockKey); } }}
第二层:数据库唯一键。支付回调记录表对transaction_id建立唯一索引,保证同一支付流水号只能插入一次。
sql
CREATE TABLE payment_callback_log ( id BIGINT PRIMARY KEY AUTO_INCREMENT, transaction_id VARCHAR(64) NOT NULL COMMENT '支付流水号', channel VARCHAR(20) NOT NULL, payload TEXT, created_at DATETIME, UNIQUE KEY uk_transaction_id (transaction_id));
java
@Transactionalpublic void doHandle(PaypalEvent event) { try { paymentCallbackLogMapper.insert(log); // 可能因唯一键冲突抛异常 // 更新订单状态 orderService.updateStatus(event.getOrderNo(), OrderStatus.PAID); } catch (DuplicateKeyException e) { log.info("回调已处理过: {}", event.getTransactionId()); return; }}
第三层:订单状态前置检查。在更新订单前,再次查询当前订单状态,若已经是“已支付”或“待采购”,则直接返回。
java
public void updateOrderStatus(String orderNo, OrderStatus targetStatus) { Order order = orderMapper.selectByOrderNo(orderNo); if (order.getStatus() == OrderStatus.PAID || order.getStatus() == OrderStatus.PENDING_PURCHASE) { log.info("订单状态已更新,无需重复处理: {}", orderNo); return; } // 乐观锁更新 int rows = orderMapper.updateStatus(orderNo, oldStatus, targetStatus); if (rows == 0) { throw new OptimisticLockException("订单状态已被其他线程修改"); }}
三、补偿机制
极端情况下,回调可能丢失(网络问题)。Taoify跨境电商还实现了定时任务,扫描“待支付”状态超过30分钟的订单,主动向支付网关查询支付状态,确保最终一致性。
java
@Scheduled(cron = "0 /10 ?")public void syncPaymentStatus() { List pendingOrders = orderMapper.selectByStatus(OrderStatus.PENDING_PAYMENT, Duration.ofMinutes(30)); for (Order order : pendingOrders) { PaymentStatus status = paymentGateway.query(order.getTransactionId()); if (status == PaymentStatus.SUCCESS) { orderService.updateStatus(order.getOrderNo(), OrderStatus.PAID); } else if (status == PaymentStatus.FAILED) { orderService.updateStatus(order.getOrderNo(), OrderStatus.CANCELLED); } }}

目录
相关文章
|
1天前
|
消息中间件 XML API
商品采集服务设计:1688/淘宝链接自动抓取与解析
本文详解代购独立站商品采集实现:基于HttpClient+Jsoup+正则解析淘宝/1688链接,优先调用淘宝官方API,1688采用模拟请求;通过异步消息队列(阿里云MNS)解耦耗时操作,配合代理IP池、重试机制与死信处理,保障百万级日采集稳定高效。(239字)
24 0
|
21小时前
|
人工智能 自然语言处理 运维
生成式 AI 驱动网络钓鱼攻击机理与防御技术研究
本文针对AI驱动的新型网络钓鱼攻击,系统分析其技术机理与演化趋势,提出“事前预警—事中检测—事后溯源”三层防御体系,原创实现文本语义检测、恶意URL识别、身份合法性校验三类工程化模块。实测综合识别准确率达91.3%,误报率低于1.2%,为政企单位提供可落地的AI钓鱼防御方案。(239字)
24 0
|
17小时前
|
消息中间件 人工智能 安全
01|什么是 Agent Harness:为什么大模型需要一个“工程外壳”
Agent Harness 是连接大模型与真实工程环境的执行层,解决AI“只会生成文本、无法完成任务”的痛点。它整合上下文管理、工具调用、安全执行、权限控制、结果验证与记忆机制,将自然语言指令转化为可观察、可控制、可验证的工程动作闭环,是AI真正落地开发的关键基础设施。(239字)
31 0
|
2天前
|
机器学习/深度学习 并行计算 算法
粒子群优化(PSO)改进算法在全局最优解搜索中的应用
粒子群优化(PSO)改进算法在全局最优解搜索中的应用
42 0
|
2天前
|
人工智能 IDE 搜索推荐
通义灵码更名Qoder CN,阿里云AI智能编码工具:个人 / 企业版定价、模型与权益对照表
阿里云Qoder CN(原通义灵码)是智能AI编程助手,支持JetBrains/VS Code插件、独立IDE及CLI等多种形态。提供个人社区版(免费)、专业版(59元/月)、企业标准版(99元/人/月)及VPC版(199元/人/月),含Qwen/GLM/Kimi等多模型选择与Credits计费体系。阿里云Qoder CN官网:https://t.aliyun.com/U/BI1WfZ
240 0
|
9天前
|
数据采集 存储 算法
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
本文探讨视频RAG中的核心挑战——如何为无时间结构的视频转录文本设计有效分块策略。对比传统文本分块,提出基于停顿、重叠窗口、递归切分及LLM驱动的主题分块四层方案,实现细粒度检索与全局理解兼顾,提升视频内容检索准确性与上下文完整性。
131 13
视频 RAG 中分块策略:基于停顿、滑动窗口与基于 LLM 的方法
|
9天前
|
人工智能 供应链 数据可视化
长江商学院CIO徐斌:AI时代,组织的进化逻辑与人才转型新思维
徐斌,长江商学院CIO、计算机博士,20年世界500强及上市公司高管经验,首创数字化“三驾马车”方法论(流程变革、IT固化、数字运营),成功主导得力集团全链路转型,助力其获评首批浙江省未来工厂。
|
2天前
|
缓存 人工智能 JSON
阿里云通义千问 Qwen3.7-Max:能力特性、优势对比与订阅方案解析
阿里云百炼平台旗舰模型Qwen3.7-Max,支持100万Token超长上下文、深度思考模式与工具调用,专攻复杂推理与智能体任务。现免费领100万Tokens,API调用享5折优惠,仅限华北2地域,需通过Token Plan团队版订阅。快速体验Qwen3.7-Max:https://t.aliyun.com/U/fPVHqY
|
1天前
|
人工智能 JavaScript 前端开发
Codex新手入门
Codex CLI是OpenAI推出的开源终端AI编程助手,基于Rust构建,响应超快(240+ tokens/s),成本仅Claude Code的1/3。支持文件系统操作、并行任务与模型切换,兼顾安全沙箱与高效开发,专为快速原型设计而生。
|
6天前
|
API
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态
阿里云微服务引擎 MSE 及 API 网关 2026 年 5 月产品动态。