2

スタンドアロンの Java アプリケーションで JTA をセットアップするために 2 日以上苦労しましたが、残念ながら id が機能しませんでした。助けていただければ幸いです。

一般情報:

  • 春のバージョン: 3.2.3
  • 休止状態のバージョン: 4.2.3
  • Jbossts バージョン: 4.17.7、narayana-jta.jar のみをクラスパスに追加しました。

春の設定ファイル:

<bean class="com.arjuna.ats.jta.TransactionManager" factory-method="transactionManager" id="arjunaTransactionManager" />
<bean class="com.arjuna.ats.jta.UserTransaction" factory-method="userTransaction" id="arjunaUserTransaction" />

<bean class="org.springframework.transaction.jta.JtaTransactionManager" id="transactionManager">
    <property name="transactionManager">
        <ref bean="arjunaTransactionManager" />
    </property>
    <property name="userTransaction">
        <ref bean="arjunaUserTransaction" />
    </property>
</bean>

<tx:annotation-driven />

ハイバネート構成ファイル:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
  "-//Hibernate/Hibernate Configuration DTD//EN"
  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- Database connection settings -->
        <property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
        <property name="connection.url">jdbc:sqlserver://localhost:1433;databaseName=TestDB</property>
        <property name="connection.username">user</property>
        <property name="connection.password">password</property>

        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">1</property>

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
        <property name="current_session_context_class">jta</property>

        <!-- Disable the second-level cache -->
        <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>

        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

        <property name="transaction.factory_class">org.hibernate.transaction.JTATransactionFactory</property>
        <property name="transaction.jta.platform">org.hibernate.service.jta.platform.internal.JBossStandAloneJtaPlatform</property>
    </session-factory>
</hibernate-configuration>

この時点で、休止状態のセッション ファクトリを作成する必要があり、プログラムで作成したいので、次のコード スニペットを使用しました。ここでは、春の LocalSessionFactoryBean を作成して休止状態の構成リソースに渡し、そこから SessionFactory を取得します。 .getObject() メソッド。

このコードは正しく機能し、SessionFactory オブジェクトを作成します。このオブジェクトは次のコード スニペットで使用されます。

LocalSessionFactoryBean sessionFactoryBean = new LocalSessionFactoryBean();
JtaTransactionManager trxManager = applicationContext.getBean(JtaTransactionManager.class);
sessionFactoryBean.setJtaTransactionManager(trxManager);
sessionFactoryBean.setConfigLocation(resource);
sessionFactoryBean.afterPropertiesSet();
SessionFactory sessionFactory = sessionFactoryBean.getObject();

その後、TABLE への挿入を行う Service クラスがあります。

package com.core.service;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;

@Component
@Scope("prototype")
public class TestService {

    @Transactional
    public void testTrx() throws Exception {
        SessionFactory sessionFactory = // retrieve session factory created before

        Session session = sessionFactory.getCurrentSession();
        Query query = session.createSQLQuery("insert into TABLE1 (col1, col2) values (:v1, :v2)");
        query.setParameter("v1", "value1");
        query.setParameter("v2", "value2");

        query.executeUpdate();
    }
}

最後に、Spring コンテキストをロードしてすべてを初期化し、次の行を実行する JUnit テスト:

@Test
public void testTransactionRollback() throws Exception {
    TestService testService = applicationContext.getBean(TestService.class);
    testService.testTrx();
}

問題: JUnit テストを実行すると、緑色のバーが表示され、テーブルに挿入する SQL ステートメントがあることがわかります。また、トランザクションが開かれてコミットされていることがわかりますが、データベースにアクセスすると、そうではありません。挿入された行が表示されません。

私の結論:休止状態の構成connection.autocommit=trueを設定しようとしたところ、行がデータベースに正しく作成されたので、はい JTA トランザクションが開かれ、閉じられたが、休止状態セッション ファクトリはそれらを使用しておらず、代わりに使用していると仮定します独自の。いくつかの構成がありませんか?

15:14:20.423 [main]            DEBUG o.s.b.f.s.DefaultListableBeanFactory - Finished creating instance of bean 'testService'
15:14:20.425 [main]            DEBUG o.s.b.f.s.DefaultListableBeanFactory - Returning cached instance of singleton bean 'transactionManager'
15:14:20.432 [main]            DEBUG o.s.t.jta.JtaTransactionManager - Creating new transaction with name [com.core.service.TestService.testTrx]: PROPAGATION_REQUIRED,ISOLATION_DEFAULT; ''
15:14:20.448 [main]            INFO  com.arjuna.ats.arjuna - ARJUNA012163: Starting service com.arjuna.ats.arjuna.recovery.ActionStatusService on port 36097
15:14:20.453 [main]            INFO  com.arjuna.ats.arjuna - ARJUNA012337: TransactionStatusManagerItem host: 127.0.0.1 port: 36097
15:14:20.460 [main]            INFO  com.arjuna.ats.arjuna - ARJUNA012170: TransactionStatusManager started on port 36097 and host 127.0.0.1 with service com.arjuna.ats.arjuna.recovery.ActionStatusService
15:14:20.488 [main]            DEBUG o.s.b.f.s.DefaultListableBeanFactory - Returning cached instance of singleton bean 'sessionFactoryManagerImpl'
15:14:20.524 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Connection provider reports to not support aggressive release; overriding
15:14:20.533 [main]            DEBUG o.h.e.t.i.TransactionCoordinatorImpl - successfully registered Synchronization
15:14:20.565 [main]            DEBUG org.hibernate.SQL - insert into TABLE1 (col1, col2) values (?, ?)
Hibernate: insert into TABLE1 (col1, col2) values (?, ?)
15:14:20.566 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Obtaining JDBC connection
15:14:20.566 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Obtained JDBC connection
15:14:20.575 [main]            DEBUG o.h.e.q.spi.NativeSQLQueryPlan - bindNamedParameters() value1 -> v1 [1]
15:14:20.582 [main]            DEBUG o.h.e.q.spi.NativeSQLQueryPlan - bindNamedParameters() value2 -> v2 [2]
15:14:20.589 [main]            DEBUG o.s.t.jta.JtaTransactionManager - Initiating transaction commit
15:14:20.590 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Aggressively releasing JDBC connection
15:14:20.590 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Releasing JDBC connection
15:14:20.590 [main]            DEBUG o.h.e.j.i.LogicalConnectionImpl - Released JDBC connection
15:14:20.595 [Listener:36097]  DEBUG com.arjuna.ats.arjuna - Recovery listener existing com.arjuna.ats.arjuna.recovery.ActionStatusService
4

1 に答える 1

1

データベース接続が JTA にバインドされていないためだと思います。休止状態のみを JTA と同期しました。接続を作成するには、com.arjuna.ats.jdbc.TransactionalDriver を使用する必要があります。

TransactionalDriver arjunaJDBC2Driver = new TransactionalDriver();
Connection connection = arjunaJDBC2Driver.connect(url, dbProps);

春の例:

 <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <property name="driverClassName">
   <value>com.arjuna.ats.jdbc.TransactionalDriver</value>
  </property>
  <property name="url" value="jdbc:arjuna:mysql://host:3306/dbName"/>
  <property name="connectionProperties">
    <ref bean="dsProps"/>
  </property>
 </bean>

この助けを願っています

于 2013-11-21T08:28:06.027 に答える