java - XA 感知数据结构(非数据库)

标签 java data-structures transactions xa

背景知识:我遇到了一个问题,我越深入地研究它,就越发现 XA 似乎是正确的解决方案。我有一个“缓存”,它基本上是一个内存数据结构(树形结构),用于保存一些处理过的信息。使用Spring,我们设置了数据库,并使用了@Transactional,它一直运行得非常好。对于大型复杂的业务逻辑,ACID 在我们的数据库中是正确的,一切都很棒。问题是我们在内存中的数据结构在设计上并不是事务性

我已经了解了本地交易和全局交易之间的差异,而全局交易似乎正是我所需要的。当我们执行逻辑时,我们使用“缓存结构”作为我们做出决策的一种方式。然后,这些更改需要传播到数据库,但如果需要回滚,则数据库会执行此操作,而“缓存”则不会。

问题我的自定义数据结构需要javax.transaction.xa.XAResource接口(interface)吗?我对 XA 的理解是否正确,但不理解它在非数据库/JMS/等中的使用。设置但更简单的东西?我不介意投入工作来基本上包装我的结构并实现它,但我不确定它是否会实现我真正寻找的目标。

TLDR:对于不涉及复杂数据库的更简单的数据结构,实现javax.transaction.xa.XAResource是否可行,或者有什么我不理解的JTA

最佳答案

XAResource 不是特定于数据库的,可以通过其他类型的资源管理器来实现。最常见的是消息队列系统(例如 JMS),但许多缓存/数据网格产品也支持事务使用,请参见例如

http://infinispan.org/docs/9.0.x/user_guide/user_guide.html#transactions

请注意,根据您的要求,缓存层可能表现为同步而不是 XAResource。一些 ORM 系统以这种方式工作,例如预提交 session 刷新。

如果您不需要恢复,XAResource 是一个相对简单的实现接口(interface),但前提是您的数据源已经具备处理底层属性(原子性、一致性和隔离性)的能力。例如,您的 API 中的缓存读取或写入是什么样的?如果它没有在缓存结构上操作的事务上下文的概念,那么在查看 XA 之前您将遇到一个必须解决的问题。

关于java - XA 感知数据结构(非数据库),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45509634/

相关文章:

java - RecyclerView 项目单击的 Bottom Sheet 对话框

Java 作用域和生命周期(内部类)

c# - 哪种算法用于在数字范围内查找空数字范围?

javascript - firebase 事务和 if-then-else 行为

java - 在 Windows 中使用 java 查找特定的注册表项

java - 与 NameResolverProvider 相关的 gRPC 异常

c - 在c中加载位图字体

regex - Perl - 使用正则表达式来匹配哈希键或值中的输入

sql-server - 由于不同的隔离级别导致的 SQL Server 事务错误

sql - 从后端在事务查询中提交空闲