我的独立应用程序已经使用narayana事务管理器与其他XA资源进行JTA事务,现在我也在尝试将其与Hiberante集成。因此Hibernate事务也在JTA超越范围内执行-
hibernate.cfg.xml
<property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>
<property name="hibernate.transaction.factory_class">
org.hibernate.transaction.JTATransactionFactory</property>
<property name="hibernate.transaction.manager_lookup_class">
<!-- org.hibernate.transaction.JBossTransactionManagerLookup -->com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionManagerImple
</property>
<property name="hibernate.current_session_context_class">jta</property>
其他爪哇会议 -
registry.applySetting(AvailableSettings.JTA_PLATFORM, "org.hibernate.service.jta.platform.internal.JBossStandAloneJtaPlatform");
registry.applySetting(AvailableSettings.TRANSACTION_COORDINATOR_STRATEGY, "jta");
这就是我开始交易的方式 -
TransactionManager transactionManager =com.arjuna.ats.jta.TransactionManager.transactionManager();
transactionManager.begin();
Session session = currentSessionContext.currentSession();
session.joinTransaction();
System.out.println("is joined "+session.isJoinedToTransaction());
session.update(obj);
transactionManager.commit();
session.close();
sessionFactory.close();
现在的问题是,db只在调用sessionFactory.close()后才显示会话的更改,而不是应该在transactionManager.commit()上显示。
如何配置它以在transactionManager之后更新数据库。提交()?
你很接近了。缺少的是事务管理器的JDBC连接登记,参见https://jbossts.blogspot.com/2017/12/narayana-jdbc-transactional-driver.html.
这个额外的步骤是必要的,因为Narayana实现了JTA规范,而JTA使用的是XAResources而不是JDBC连接。需要一些粘合代码来a)为JDBC连接提供XAResource)将该资源登记到事务