java – “回滚”更改的最佳方法是什么?

前端之家收集整理的这篇文章主要介绍了java – “回滚”更改的最佳方法是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

好吧,所以我有一个Spring应用程序,它接受网络表示并启动虚拟机来表示传入的网络.

它使用低级API来调出VM,不涉及数据库.

我需要弄清楚如何处理用户提交10个节点(或任意数量)网络模型并且应用程序通过并构建网络(启动VM)的情况,如果节点无法启动我想要能够对此做出反应.我希望能够回滚我的更改(即销毁所有已创建的节点).

我被告知我需要查看“事务”,但我不确定当我不使用数据库时是否适用于这种情况.

作为旁注,如果用户发送该请求,我确实有逻辑来取消节点.

我的问题是 – 我该如何处理?

此外,这是这个问题的最佳堆栈溢出吗?

最佳答案
您似乎正在寻找事务行为,特别是原子性(“全有或全无”).但通常“交易”意味着某些保证(特别是围绕ACID属性),如果涉及分钟量级的人类时间尺度,将难以或不可能实现.

可能“错误补偿的工作流程”更像是你在这里寻找的东西.

我会手动实现这个,可能还有工具支持(例如工作流引擎).启动生成网络的流程,并跟踪当前进度,例如创建的VM,正在进行的VM等.如果存在需要回滚的错误,则让另一个进程执行清理.清理过程本身的行为可能会失败,因此在生成报告“此清理步骤失败”之前,它可能会重试其各个步骤几次.

如果涉及共享资源,那么您还需要实现某种隔离机制.有时这很容易 – 例如,DHCP可以帮助您避免重复的IP.如果您正在更新DNS区域文件,那么您希望同步对该区域文件的访问以避免并发写入.等等.

猜你在找的Spring相关文章