为什么长期事务不被看好:Saga 的现实优势
副标题 / 摘要 长期事务会长时间占用资源、锁与连接,导致系统吞吐下降。Saga 用补偿机制更符合分布式现实。 目标读者 负责分布式事务的后端工程师 设计跨服务流程的架构师 需要权衡一致性与可用性的团队 背景 / 动机 在 SOA 或微服务中,一个业务流程可能跨多个系统。 传统的长期事务会锁住资源,导致性能与可用性问题。 核心概念 长期事务:跨服务长时间持锁 Saga:一系列本地事务 + 补偿操作 补偿:失败后用反向操作修正状态 实践指南 / 步骤 把业务拆成可独立提交的步骤 为每个步骤设计补偿动作 用编排或协作方式驱动流程 记录状态,支持重试与恢复 可运行示例 # 简化 Saga:下单 -> 扣库存 -> 扣款 def reserve_stock(): return True def release_stock(): print("compensate: release stock") def charge_payment(): raise RuntimeError("payment failed") def refund_payment(): print("compensate: refund") def run_saga(): try: if not reserve_stock(): return False charge_payment() return True except Exception: release_stock() refund_payment() return False if __name__ == "__main__": print(run_saga()) 解释与原理 长期事务依赖全局锁与强一致,会在高并发场景中放大等待与失败率。 Saga 把事务拆小,允许最终一致,从而提高可用性。 ...