2015-02-06 46 views
1

我們的應用程序當前使用的是在JBoss standalone.xml中定義的數據源,基本上我們需要在應用程序中定義它,而不是在容器中定義一段時間。我們目前的設置是;在容器外定義一個jta數據源

application-context.xml;

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> 
     <property name="persistenceXmlLocation" value="classpath:META-INF/persistence.xml" /> 
     <property name="persistenceUnitName" value="rtsPersistenceUnit" /> 
     <property name="packagesToScan"> 
      ... 
     </property> 
     <property name="jpaVendorAdapter"> 
      <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> 
       <property name="database" value="ORACLE" /> 
       <property name="databasePlatform" value="org.hibernate.dialect.Oracle10gDialect"/> 
      </bean> 
     </property> 
</bean> 

persistance.xml:

<persistence xmlns="http://java.sun.com/xml/ns/persistence" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd" 
    version="2.0"> 

    <persistence-unit name="rtsPersistenceUnit" transaction-type="RESOURCE_LOCAL"> 

     <provider>org.hibernate.ejb.HibernatePersistence</provider> 

     <jta-data-source>java:/jdbc/RTSdb</jta-data-source> 

     <class>...</class> 

     <exclude-unlisted-classes>true</exclude-unlisted-classes> 

     <properties> 
      <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" /> 
      <property name="hibernate.show_sql" value="true"/> 
      <property name="hibernate.hbm2ddl.auto" value="validate" /> 
      <property name="hibernate.transaction.flush_before_completion" value="true" /> 
     </properties> 

    </persistence-unit> 

</persistence> 

datasource.xml:

<bean id="rtsDatasource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
    <property name="driverClassName" value="oracle.jdbc.OracleDriver"/> 
    <property name="url" value="..."/> 
    <property name="username" value="..."/> 
    <property name="password" value="..."/> 
</bean> 

基本上所有我想要的是行

<jta-data-source>java:/jdbc/RTSdb</jta-data-source> 

從datasource.xml閱讀而不是去容器(JBoss)。 它看起來很簡單,但在閱讀了一些Spring和Oracle文檔後,我找不到答案。

回答

2

是的,您可以使用符合JTA的事務管理器,如Atomikos或Bitronix。他們各自的網站有關於如何使用Spring進行配置的文檔。在一般情況下,你必須遵循以下(如果使用Atomikos公司)的步驟:(你的情況rtsDatasource

  1. 保留現有的XA數據源或創建一個,如果尚未使用(例如,如果有人有一個非XA數據源,該數據源必須先轉換爲XA數據源)。
  2. 將XA數據源包裝在AtomikosDataSourceBean中。
  3. 將您的EntityManagerFactory指向新的AtomikosDataSourceBean實例。
  4. 聲明XA事務管理器和XA用戶事務。
  5. 在Spring中包裝XA事務管理器JtaTransactionManager
  6. 使用彈簧JtaTransactionManager

下面顯示了使用H2數據庫,Hibernate 4,Spring 4和Atomikos 4的簡短配置代碼片段。

<bean class="org.h2.jdbcx.JdbcDataSource" id="originalDataStore" lazy-init="true">...</bean> 

<bean class="com.atomikos.jdbc.AtomikosDataSourceBean" id="dataSource" init-method="init" destroy-method="close"> 
    <property name="uniqueResourceName" value="xaDS"/> 
    <property name="xaDataSource" ref="originalDataStore"/> 
    <property name="poolSize" value="3"/> 
</bean> 

<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory"> 
    <property name="dataSource" ref="dataSource"/> 
    <property name="jpaProperties"> 
    <props> 
     <prop key="hibernate.transaction.jta.platform">com.atomikos.icatch.jta.hibernate4.AtomikosPlatform</prop> 
     ... 
    </props> 
    </property> 
</bean> 

<bean class="org.springframework.transaction.jta.JtaTransactionManager" id="transactionManager"> 
    <property name="transactionManager"> 
    <bean class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close"> 
     <property name="forceShutdown" value="false"/> 
    </bean> 
    </property> 
    <property name="userTransaction"> 
    <bean class="com.atomikos.icatch.jta.J2eeUserTransaction"> 
     <property name="transactionTimeout" value="300"/> 
    </bean> 
    </property> 
    <property name="allowCustomIsolationLevels" value="true"/> 
</bean> 

<transaction:annotation-driven transaction-manager="transactionManager"/> 

有關詳細信息,請參閱this app

相關問題