EJB,XA事务和错误处理

时间:2013-10-06 10:10:31

标签: jdbc transactions ejb jms xa

我们认为这是一个相当常见的XA用例:

  1. 从队列中读取消息
  2. 将一些数据写入数据库
  3. 将响应消息写入出队列(与队列不同)
  4. 但是我们还需要一种方法来处理内部错误和有害消息。我们想到的控制流程是这样的:

    1. 从队列中读取消息
    2. 写入数据库
      • 如果有异常回滚数据库事务
      • 如果没有异常,则在数据库上运行commit phase1
    3. 如果一切顺利(没有回滚和提交阶段1确定)将成功消息写入出队列
    4. 如果数据库上的提交阶段1失败或者存在异常并且数据库事务已回滚,则向外部队列写入失败消息
    5. 提交队列,队列和数据库(除非由于例外而提交)
    6. 这是一个很好的方法,我们应该采用不同的方式吗?我们如何用EJB做到这一点?

      我们在JBoss AS 7.2 / EAP 6.1上使用EJB 3.1,直接对Narayana进行编码是一种选择。 JDBC驱动程序是ojdbc7-12.1.0.1,JMS RAR是MQ Series(不知道版本)。

1 个答案:

答案 0 :(得分:2)

您可以做的是使用Java EE事件机制在事务失败时获取通知并创建后续输出消息。

您需要使用新事务写入out队列,以避免回滚写入消息。

您仍会在输入队列中显示导致异常的消息,因为回滚将阻止成功使用。您需要单独处理它,例如由JMS提供程序处理。