请问Seata事务执行完成后 如何不删除branch和global记录?

请问Seata事务执行完成后 如何不删除branch和global记录?

展开
收起
真的很搞笑 2023-05-30 15:47:41 253 发布于黑龙江 分享
分享
版权
举报
1 条回答
写回答
取消 提交回答
  • 如果你想保留branch和global记录,有以下几种方法:

    - 修改Seata的配置文件,将**store.db.globalTable**和**store.db.branchTable**的值改为你想要保留的表名,比如**global_table_history**和**branch_table_history**。这样,Seata会在执行完一个全局事务后,将branch和global记录从原表中移动到新表中,而不是直接删除。
    - 修改Seata的源码,将**GlobalTransactionServiceImpl#deleteGlobalSession()**和**BranchTransactionServiceImpl#deleteBranchSession()**方法中的删除逻辑注释掉或者修改为更新逻辑。这样,Seata会在执行完一个全局事务后,将branch和global记录的状态更新为已完成,而不是直接删除。
    - 修改数据库的触发器或者存储过程,将branch和global表设置为只读或者增加备份逻辑。这样,在Seata尝试删除branch和global记录时,会抛出异常或者将记录备份到其他表中。 
    
    2023-10-13 10:56:14 举报
    赞同 1 评论

    评论

    全部评论 (0)

    登录后可评论

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

还有其他疑问?
咨询AI助理
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等