Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
JPA(Hibernate)、JTA(JOTM)和Tomcat_Hibernate_Jpa_Jta_Jotm - Fatal编程技术网

JPA(Hibernate)、JTA(JOTM)和Tomcat

JPA(Hibernate)、JTA(JOTM)和Tomcat,hibernate,jpa,jta,jotm,Hibernate,Jpa,Jta,Jotm,我正在开发一个以JPA(Hibernate)为后端的应用程序。 我对每个实体都有一个DAO和JPADAO,并且我的流程将多个实体作为一个工作单元进行更新,因此我决定使用JTA,因为它允许我控制事务,所以下面是我的代码的外观 persistence.xml <persistence-unit name="Pub" transaction-type="JTA"> <provider>org.hibernate.ejb.HibernatePersistenc

我正在开发一个以JPA(Hibernate)为后端的应用程序。 我对每个实体都有一个DAO和JPADAO,并且我的流程将多个实体作为一个工作单元进行更新,因此我决定使用JTA,因为它允许我控制事务,所以下面是我的代码的外观 persistence.xml

    <persistence-unit name="Pub" transaction-type="JTA">
      <provider>org.hibernate.ejb.HibernatePersistence</provider>
       <jta-data-source>java:comp/env/jdbc/dcapps</jta-data-source>

     <property name="hibernate.dialect" value="org.hibernate.dialect.InformixDialect"/>
        <property name="transactionSynchronizationRegistryName" value="java:comp/env/TransactionSynchronizationRegistry"/>
        <property name="hibernate.transaction.jta.platform" value="org.hibernate.service.jta.platform.internal.JOTMJtaPlatform"/>


            web.xml
      <resource-ref>
  <description>DB Connection</description>
  <res-ref-name>jdbc/dcapps</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>

您没有提到正在使用哪个版本的JOTM,但我在使用v2.2.1时遇到了完全相同的问题。降级到v2.1.9版本为我解决了这个问题

很明显,它最近已经修复了,看到了吗

致以亲切的问候

巴里

<resource-env-ref>
<description>JTA transaction manager</description>
<resource-env-ref-name>jta/UserTransaction</resource-env-ref-name>
<resource-env-ref-type>javax.transaction.UserTransaction</resource-env-ref-type>
</resource-env-ref>

    <resource-env-ref>
<description>JTA Transaction Synchronization Registry</description>
<resource-env-ref-name>TransactionSynchronizationRegistry</resource-env-ref-name>
<resource-env-ref-type>javax.transaction.TransactionSynchronizationRegistry
 </resource-env-ref-type>
 </resource-env-ref>


         content.xml(Tomcat 7)
        <Resource name="jdbc/dcapps" auth="Container" type="javax.sql.DataSource"
               maxActive="20" maxIdle="10" maxWait="-1"
               username="dcapps" password="dcapps" driverClassName="com.informix.jdbc.IfxDriver"
               url="jdbc:informix-sqli://fddb.fd.gtwy.dcn:7101/fd_test:INFORMIXSERVER=fd_ecf"/>

 <Resource
        name="TransactionSynchronizationRegistry"
        auth="Container"
        type="javax.transaction.TransactionSynchronizationRegistry"
        factory="org.objectweb.jotm.TransactionSynchronizationRegistryFactory"/>

<Transaction
        factory="org.objectweb.jotm.UserTransactionFactory"
        jotm.timeout="60"/>





        Process.java
       Context initContext = new InitialContext();
     utx  = (UserTransaction)initContext.lookup("java:comp/UserTransaction");
             dktPartDAO.getEntityManager().joinTransaction();
            dkttextDAO.getEntityManager().joinTransaction();
            reqHDAO.getEntityManager().joinTransaction();
            reqDDAO.getEntityManager().joinTransaction();
            costDAO.getEntityManager().joinTransaction();
            reportDDAO.getEntityManager().joinTransaction();
            caseflagDAO.getEntityManager().joinTransaction();
            redStatusDAO.getEntityManager().joinTransaction();
            pcdktPartDAO.getEntityManager().joinTransaction();
            pcDkttextDAO.getEntityManager().joinTransaction();
                           utx.commit();
         Exception
      java.lang.IllegalStateException: Cannot get Transaction for rollback
at org.objectweb.jotm.Current.rollback(Current.java:486)
at pub.jpa.dto.support.PubDProcess.processRecords(PubDProcess.java:397)

         org.omg.CORBA.BAD_INV_ORDER: The Servant has not been associated with an ORB instance  vmcid: 0x0  minor code: 0  completed: No
at org.omg.PortableServer.Servant._get_delegate(Unknown Source)
at org.omg.PortableServer.Servant._poa(Unknown Source)
at org.objectweb.jotm._SubCoordinator_Tie.deactivate(Unknown Source)
at com.sun.corba.se.impl.javax.rmi.CORBA.Util.cleanUpTie(Unknown Source)
at com.sun.corba.se.impl.javax.rmi.CORBA.Util.unexportObject(Unknown Source)
at javax.rmi.CORBA.Util.unexportObject(Unknown Source)
at com.sun.corba.se.impl.javax.rmi.PortableRemoteObject.unexportObject(Unknown Source)
at javax.rmi.PortableRemoteObject.unexportObject(Unknown Source)