@
jimrok 传统应用服务器的 JTA 的实现一个基础是 XA 标准,比如 Jdbc Driver 的 DataSource 一般都是提供两个版本,XA 版本专门用于 JTA 环境。如果自己从无到有去实现一套 XA Resource,再参与 JTA 事务,这一套下来挺复杂的(不是不可行)。但对于 Java EE 规范支持内的资源(特别是 Jdbc,EJB,JMS 这些)几乎不用太关注事务,代码反而不复杂,后面生产环境部署,主要集中在于服务器部署方案。
当然今天 90 后很多工作中可能从来没用过应用服务器( Weblogic,Glassfish,Payara,Websphere 等)。我以前在上海帮朋友公司面试的时候,很多工作过 5 年以上的 Java 程序员都没有安装使用过 Tomcat manager ( Tomcat Web 管理界面), 应用服务器中 Console 能够管理优化很多使用的资源。实际我个人认为 Java EE 一些优秀的东西,比如 EJB remote, 还有就应用服务器的 Console 这些很好一部分现在全部丢掉了。反而最到了外部,再另外花大量时间开发什么大用户控制台(中台???)。
今天的互联网应用很多比企业应用复杂得多,传统 ACID 那一套用在一个 Component (单独运行的服务)使用就行了,或者一个 Component 完全是无状态的(越来越多的东西都是考虑使用 Serverless,特别是一些成熟的云平台,如 AWS ),不同的 Component 之间使用消息通讯。传统的事务都是发生在 ms 级,而现在分布式体系一个任务的执行更多像走一个流程,可能要跨很长时间。分布式事务这个显然用这些场景不适合了,或者回到事务最基本的概念里, 用 Unit Of Work 比较适合。至于像 atomikos 这样 JTA 的厂商,在分布式系统中,非要将 JTA 套上 TCC,为了能用上事务那些概念,我就觉得没必要了。
Redhat 的 MarkLittle 博士著有
https://www.amazon.com/Java-Transaction-Processing-Design-Implementation/dp/013035290X 记得不止一本,JBoss narayana 也算是一个专门的事务产品,除了在 Java EE,应用服务器使用外中,也可以单独使用。