没有数据库事务时,如何从头实现事务语义
副标题 / 摘要 当底层系统不支持事务时,你仍然需要一致性保障。本文给出从应用层实现“类事务”的核心思路。 目标读者 需要保证数据一致性的后端工程师 构建存储系统或中间层的开发者 负责业务可靠性的技术负责人 背景 / 动机 没有事务意味着更新失败会留下不一致状态。 在关键业务中,必须通过应用层补偿或日志保证正确性。 核心概念 写前日志(WAL):记录意图,支持回滚 锁/隔离:防止并发冲突 补偿事务:失败后反向修复 实践指南 / 步骤 为关键操作记录意图日志 设计回滚逻辑与补偿函数 用锁或版本号避免并发冲突 定期对账,检测异常状态 可运行示例 # 简化的“事务”示例:使用回滚日志 class Txn: def __init__(self, store): self.store = store self.log = [] def set(self, key, value): self.log.append((key, self.store.get(key), value)) def commit(self): for key, _, value in self.log: self.store[key] = value def rollback(self): for key, old, _ in reversed(self.log): if old is None: self.store.pop(key, None) else: self.store[key] = old if __name__ == "__main__": store = {"a": 1} tx = Txn(store) tx.set("a", 2) tx.set("b", 3) tx.rollback() print(store) 解释与原理 通过记录“修改前状态”,可以在失败后回滚。 这模拟了事务中的“原子性”,但要自己处理并发与持久化。 ...