将非事务性资源绑定到JTA事务中的几种模式

我最近发表了一篇有关如何将非事务性资源(如Web服务/微服务)绑定到全局分布式事务中的文章,以便自动处理恢复。 多年来,我经常不得不将“非事务性”系统集成到Java EE应用程序服务器中,而数据一致性通常是讨论的话题,甚至是非功能性需求。 我将“非事务性”用引号引起来,因为通常系统包含确保数据一致性的方法,例如使用调用进行补偿,但是这些系统通常不是您传统上称为事务性的。 当然,无法将Java EE应用程序服务器配置为自动处理此类资源的恢复。

以下是我们编译的模式列表,显示了面对集成非事务系统的任务时保持一致性的不同方法。

  1. 将作业写入数据库 –常见的情况是您要在出售后向您发送一封电子邮件确认信。 您无法发送电子邮件,然后尝试将销售交易提交到数据库,因为如果提交失败,则客户会收到一封电子邮件,指出他们已经购买了商品,并且您没有任何记录。 将销售交易提交到数据库后,您将无法发送电子邮件,因为如果电子邮件发送失败(例如,邮件服务器暂时关闭),则客户将无法获得其确认,也许会带有指向票证的链接他们买了。 一种解决方案是将需要发送电子邮件的事实写入持久销售的同一笔交易中。 然后,批处理或@Scheduled EJB可以定期检查以查看是否应发送电子邮件。 成功发送电子邮件后,它将更改记录的状态,以便不再发送电子邮件。 同样的问题在这里适用,您可能只能发送电子邮件,而不能更新数据库。 但是,如果您能够读取数据库,则很可能能够对其进行更新,并且由于数据库故障而发送两次相同的电子邮件不会像从不发送邮件那样糟糕,就像您未曾发送邮件一样。处理异步发送电子邮件。 像这样进行集成的一个缺点是,这意味着您无法集成需要结果的系统,以便在答复用户之前继续处理业务逻辑。 您必须异步处理集成。
  2. JMS –在与先前解决方案类似的情况下,您可以发送包含作业的JMS消息,而不是将作业写入数据库。 JMS是事务性的,但是是异步的,因此该解决方案具有与上述解决方案相同的缺点。 如果您当时无法处理工作,则无需更改待完成的工作状态,而是将消息发送到带有属性的队列中,以便仅在一定时间后处理该消息,或者发送消息发送到死信队列以进行手动处理。
  3. 通用连接器(JCA适配器) –我最近发表了一篇博客文章,描述了我创建的通用JCA资源适配器,该适配器可让您通常将非事务性资源(如Web服务)绑定到JTA事务中。 有关更多详细信息,请参见博客文章。 使用通用连接器意味着事务管理器将在需要提交,回滚或恢复事务时执行回调,因此您只需要编写响应这些事件的应用程序代码即可。
  4. CDI事件 –在字段和字段上使用@Inject @Qualifier Event<T> field.fire(t); 当您要在方法参数上触发事件&@ @Observes(during=TransactionPhase.AFTER_FAILURE) @Qualifier T时,在事务失败后,将为每个触发的事件调用该方法。 这样,您可以对事务失败时进行一些补偿。 同样,您可以使用不同的交易阶段来执行不同的操作,例如AFTER_SUCCESS来执行呼叫以确认初始预订。 我们甚至使用了这些机制来延迟对远程系统的调用,例如在提交之前将工作发布到工作流引擎,以便确保在远程系统调用完成之前,复杂过程中的所有验证逻辑都已完成。制作。 请参阅下面的数字12。
  5. 定制解决方案 –如果您真的可以证明其合理性,则可以构建带有超时等内容的复杂代码,其中涉及批处理和脚本,这些批处理和脚本使用远程资源来处理提交,回滚和恢复事务。 您需要问自己的问题是您是编写业务代码方面的专家还是有效编写事务管理器方面的专家。
  6. 业务流程引擎 –现代引擎可以将各种远程资源集成到业务流程中,并且它们倾向于处理故障恢复之类的事情。 他们通常重试失败的呼叫,并且在远程系统再次联机之前,它们可以持久地处理流程状态,以便可以恢复流程。 BPEL支持补偿以确保整个环境的一致性,而不是提交和回滚。
  7. Atomikos&TCC –一种能够将Web服务绑定到JTA交易中的产品。 据我所知,它是一个独立的事务管理器,可以在Java EE应用程序服务器之外运行。 但是我没有这个产品的经验。
  8. WS-AT –使用专有配置(和/或注释),您可以设置两个应用程序服务器以在全局事务中完成其工作。 尽管这听起来很有希望,但我还没有遇到实现WS-AT的高效系统。 尽管JBoss正在准备支持REST服务的管道 ,但实际上仅支持SOAP Web服务。
  9. EJB –远程EJB:Java EE应用程序服务器能够在较长时间内将事务上下文从一台服务器传播到另一台服务器。 如果您需要调用恰巧是使用Java EE堆栈实现的服务,为什么不使用远程EJB而不是通过Web服务调用它来进行调用,以便将服务免费绑定到全局事务中呢?
    –本地EJB:如果您要调用的服务恰好是使用EJB技术用Java编写的,为什么不只是在本地部署它,而不是花更多的精力通过SOAP Web服务进行远程调用呢? 您可能会从企业架构师那里获得布朗尼点,但是可扩展性和可组合性是否已与性能,一致性和简单性进行了比较? 当然,具有微服务趋势的现代架构意味着部署许多远程服务是件好事,但是总要权衡取舍,并且在决定需要远程访问景观的哪些部分时需要真正理解它。
  10. 事务回调 –与解决方案4类似,但使用事务同步 API注册在事务相关阶段调用的回调。 与CDI事件不同,这里的问题是您不知道在其中提交或回滚事务的上下文,因为不像在CDI中传递给观察方法的对象那样,回调不传递相关数据。 。 因此,如果您需要补偿交易并致电说一个Web服务来取消您在交易期间所做的操作,那么您将在何处获取所需的数据呢?
  11. 将XA资源注册到事务中 –添加XAResource接口的自定义实现,您可以使用enlistResource方法将其enlistResource到事务中。 不幸的是,commit / rollback方法仅被调用一次,如果它们失败了,在恢复过程中将不会被再次调用。
  12. 最后是非事务性资源 –如果无法实现其他模式,并且您不需要在流程中的特定时间调用资源,例如,您需要发送电子邮件作为交易的一部分,但是不需要不管您是在第一步还是最后一个步骤中执行此操作,都必须始终在流程结束时(即在提交事务之前)立即调用它。 与远程系统调用失败的机会相比,事务无法提交的机会相对较小(特别是如果所有SQL已刷新到数据库中的情况)。 如果调用失败,则回滚事务。 如果调用成功,则提交事务。 如果事务然后在提交期间失败,并且对您补偿非事务性资源很重要,那么您将需要使用上述模式之一向系统添加一些补偿。

下表总结了解决方案。 恢复列指示此解决方案支持的自动恢复级别。 同步性列指示如果需要响应以继续处理,是否可以使用解决方案,在这种情况下,您需要同步解决方案。 这里的同步与阻塞与非阻塞无关,而是与计时以及是否需要响应才能完成活动的处理有关。

同步性 复苏
1)将作业写入数据库 异步 手册1
2)JMS 异步 半自动2
3)通用连接器(JCA适配器) 同步 自动3
4)CDI活动 异步 不支持4
5)定制解决方案 取决于您的实现 取决于您的实现
6)业务流程引擎 同步 支持5
7)Atomikos和TCC 没有经验,大概是同步的 没有经验,大概支持
8)WS-AT(配置) 没有经验,大概是同步的 没有经验,大概支持
9)EJB 同步 自动6
10)交易回调 同步 不支持4
11)招募XA资源进行交易 同步 不支持4
12)非交易资源排在最后 异步,因为必须最后调用 不支持


脚注:

  1. 手动恢复–您需要编程处理失败时的处理方式,即在将工作置于“死信队列”之前应尝试重试的频率。
  2. 如果将队列配置为持久性,JMS将自动尝试重新发送消息。 但是,程序员尝试处理失败的消息将由您自己决定。
  3. 事务管理器将不断尝试提交/回滚未完成的事务,直到管理员介入以处理长时间运行的故障为止。
  4. 回调仅被调用一次,因此您只有一次机会
  5. 业务流程引擎将反复尝试重新调用失败的Web服务调用。 补偿也是如此。 该行为通常是可配置的。
  6. 远程EJB:JTA事务跨其他应用服务器传播,因此协调事务管理器会将事务恢复传播到绑定到该事务的其他应用服务器。
    本地EJB:使用本地EJB意味着它们对数据库的任何调用都将在与应用程序代码相同的事务中处理。 如果本地EJB使用其他数据库,则应对所有数据库,消息队列等使用XA驱动程序,以便事务管理器可以使用两阶段提交来确保系统范围的一致性。

在所有这些中,我目前最喜欢的是通用连接器 。 它支持需要响应的呼叫以及完全自动的恢复。 这意味着我可以专注于编写业务代码,而不是真正属于框架的样板代码。

如果您知道其他方法,请与我联系或发表评论,以便我可以将它们添加到列表中。

翻译自: https://www.javacodegeeks.com/2015/08/several-patterns-for-binding-non-transactional-resources-into-jta-transactions.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357941.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vscode中文设置不生效_VSCode详细安装教程

1.下载https://code.visualstudio.com/download 是Microsoft&#xff08;微软的产品&#xff09;User Installer版&#xff1a;会安装在当前计算机帐户目录,意味着如果使用另一个帐号登陆计算机将无法使用别人安装的vscode。System Installer版&#xff1a;安装在非用户目录,例…

windows查看密码工具

windows查看密码工具windows前言 本篇介绍几款优秀的Windows上的密码抓取工具&#xff0c;每个工具都有自己的特点非常实用&#xff0c;欢迎补充。 0x01 Mimikatz 个人点评&#xff1a;这款工具非常强大&#xff0c;公认的Windows密码神器。 1. 简介 Mimikat是一个法国人写的轻…

孙叫兽VUE学习笔记总结(值得收藏),很全很详细!!!

官方文档:http://vuejs.org/v2/guide/syntax.html 中文文档: https://cn.vuejs.org/v2/guide/syntax.html Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。 与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。 Vue 的核心库只关注视图层,不…

hashCode之二--Java:重写equals()和hashCode()

以下内容总结自《Effective Java》。1.何时需要重写equals()当一个类有自己特有的“逻辑相等”概念&#xff08;不同于对象身份的概念&#xff09;。2.设计equals()[1]使用instanceof操作符检查“实参是否为正确的类型”。[2]对于类中的每一个“关键域”&#xff0c;检查实参中…

毛绒材质渲染_学室内设计必进,建模渲染那都不是事儿

近年来&#xff0c;室内设计从业人员需求量和薪酬持续增长带来的是室内设计行业的飞速发展&#xff0c;而设计能力也成为“创新与创造”的不可或缺。设计能力是多方面能力的综合体现而室内效果图作为设计成果的最主要表现手段&#xff0c;是最基础也是最重要的技能之一。那么持…

2020年末总结,脚踏实地,一步一个脚印——致敬自己一年的心酸历程

摘要:恰逢官方征文,谨以此篇记录自己一年的心酸历程与前端知识的感悟。 目录 在时代工场的主要工作 我为什么从时代工场离职?

第六章 面向对象(下)

1. 不上机&#xff0c;判断下面程序的输出结果 class X {Y b new Y();X() {System.out.print("X");} } class Y {Y() {System.out.print("Y");} } public class Z extends X {Y y new Y();Z() {System.out.print("Z");}public static void mai…

如何使用Java 8函数式编程生成字母序列

我偶然发现了用户“ mip”一个有趣的堆栈溢出问题 。 问题是&#xff1a; 我正在寻找一种生成字母序列的方法&#xff1a; A, B, C, ..., Z, AA, AB, AC, ..., ZZ.可以很快将其识别为Excel电子表格的标题&#xff0c;正是这样&#xff1a; 到目前为止&#xff0c;没有答案使…

maven 打包指定依赖包_[Maven]-Maven基础-01-基础概念

Maven基础1.基础概念Maven基础概念什么是Maven什么是理想的项目构建&#xff1f;高度自动化&#xff0c;跨平台&#xff0c;可重用的组件&#xff0c;标准化的什么是依赖&#xff1f;为什么要进行依赖管理&#xff1f;自动下载&#xff0c;统一依赖管理有哪些项目信息&#xff…

关于本人在多个技术平台发布文章的声明

摘要:由于博主有经常记录博客的习惯,很多其他平台的运营或者编辑多多少少会找到我,让我在他们的平台更新文章,写这篇文章主要为了陈述事实与避免纠纷。 本博客会长期维护更新,感谢大家的理解与支持。 孙叫兽目前只在CSDN、开源中国、掘金、infoq、腾讯云+技术社区上更新博…

架构之路(八)从CurrentUser说起

CurrentUser&#xff0c;也就是当前用户&#xff0c;这是我们系统中大量使用的一个概念。 确认当前用户 当然&#xff0c;我们利用的是cookie&#xff1a;用户的ID存放在cookie中&#xff0c;服务器端通过cookie中的Id&#xff0c;查找数据库&#xff0c;得到需要的用户信息。 …

手写爬虫框架

前言 参照了Scrapy、Feapder的设计模式&#xff0c;实现的一个轻量级爬虫框架&#xff08;目前约200行代码&#xff09; 源码地址 https://gitee.com/markadc/pader 项目持续更新中…

cmseasy漏洞复现

介绍 提供可视化编辑企业网站管理系统系统、网站模板、以及相关文档资料下载,网站系统完美运 行PHP7环境中。 官方网站: https://www.cmseasy.cn/ cmseasy_7.3.8 任意文件操作漏洞复现 cmseasy_7.6.3.2逻辑漏洞复现 "无需代码&#xff0c;自由拖拽布局&#xff0c;适应…

教你如何看待程序员这个职业的前前后后

现在大家的学历基本提升上来啦&#xff0c;基本搞编程的都是本科或者大专起步&#xff0c;这里仅那本科举例。 好多大学生跟我说是计算机专业&#xff0c;软件工程专业等&#xff0c;啥都学一点&#xff0c;这样真的好&#xff1f; 对于大学生&#xff0c;如果是计算机相关专业…

请领导批阅文件怎么说_刚到公司,应该怎么喊领导,别直接说名字,高情商这样称呼...

刚到公司&#xff0c;应该怎么喊领导&#xff0c;别直接说名字&#xff0c;高情商这样称呼我们都有经历过刚刚从大学毕业出来后&#xff0c;寻求工作的场景。一般来说&#xff0c;我们都是会选择和自己大学所学专业挂钩的职业&#xff0c;在这样的情况下&#xff0c; 我们的选择…

正则表达式的汉字匹配

这里是几个主要非英文语系字符范围 2E80&#xff5e;33FFh&#xff1a;中日韩符号区。收容康熙字典部首、中日韩辅助部首、注音符号、日本假名、韩文音符&#xff0c;中日韩的符号、标点、带圈或带括符文数字、月份&#xff0c;以及日本的假名组合、单位、年号、月份、日期、时…

分屏显示_2021元旦高性价比显示器推荐——便携式显示器选购指南(分屏办公、小尺寸办公必备)...

想要告别小显示器选择困难症&#xff0c;挑选到自己心仪的小显示器&#xff0c;大家看这篇文章就够了&#xff01;显示器是PC的重要组成部分&#xff0c;在应用程序级别具有“场景”属性。显示器的要求因办公&#xff0c;娱乐和学习等不同应用而异。无论应用场景如何&#xff0…

为Jersey 2.19创建共享库以与Weblogic 12.1.3一起使用

Weblogic服务器带有一个共享库&#xff0c;因此您可以部署JAX-RS 2.0应用程序。 但是仅限于Jersey 2.5.1版&#xff0c;更改的说明并不完全清楚或直观 。 我最近加入了Oracle的新团队&#xff0c;我要做的第一件事就是着眼于升级依赖库。 现在我已经与泽西队进行了交谈&#xf…

一键反编译Android包教程

功能介绍 某些时候我们想修改apk包内容&#xff0c;比如汉化某个游戏&#xff0c;这时候就需要修改游戏apk的包内容&#xff0c;并重新签名成安卓手机识别的apk文件&#xff0c;下面详细介绍&#xff0c;文章末尾有一键修改工具。&#xff08;注意&#xff1a;此工具尚未整合修…

发现一个可视化大屏操作神器FBI,你值得一试

FineBI 是帆软软件有限公司推出的一款商业智能(Business Intelligence)产品。 FineBI 自助分析以业务需求为方向,通过便携的数据处理和管控,提供自由的探索分析。 FineBI 定位于自助大数据分析的 BI 工具,能够帮助企业的业务人员和数据分析师,开展以问题导向的探索式…