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

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

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

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

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

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

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

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

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

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

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

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

相关文章

Spring Cloud为Spring Boot应用程序提供Netflix OSS集成。 提供的功能模块包括服务发现(Eureka),断路...
Spring Cloud 学习笔记;maven配置;入门学习;基于Spring Boot 实现;服务端配置,客户端配置;
可以毫不夸张地说,这篇文章介绍的 Spring/SpringBoot 常用注解基本已经涵盖你工作中遇到的大部分常用的...
Spring中各种方式进行日期时间处理,有作用于单个实体的,也有作用于全局的,有作用于请求入参的,有作...
跨域资源共享(Cross-origin resource sharing)(CORS)是W3C的标准,大部分的浏览器都实现了这个标准...
Spring Boot使创建基于Spring的应用程序变得轻松,大部分的SpringBoot应用程序都只需要很少的Spring配置...