2016-09-24 83 views
0

我正在調查JTA事務管理器和Spring Data JPA的使用。我已成功配置Atomikos和Bitronix,並試圖配置JBossTS(Arjuna/Narayana)。如何使用Spring數據使用JBossTS(Narayana)JPA

我遵循的指示爲configuring JBossTS for Spring,並具有以下配置上來:

<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory"> 
    <property name="jpaProperties"> 
    <props> 
     <prop key="hibernate.format_sql">true"</prop> 
     <prop key="hibernate.hbm2ddl.auto">create-drop</prop> 
     <prop key="hibernate.id.new_generator_mappings">false</prop> 
     <prop key="hibernate.transaction.jta.platform">org.hibernate.engine.transaction.jta.platform.internal.JBossStandAloneJtaPlatform</prop> 
     <prop key="hibernate.use_sql_comments">true</prop> 
    </props> 
    </property> 
    <property name="jpaVendorAdapter"> 
    <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> 
     <property name="databasePlatform" value="org.hibernate.dialect.H2Dialect"/> 
     <property name="generateDdl" value="true"/> 
     <property name="showSql" value="true"/> 
    </bean> 
    </property> 
    <property name="jtaDataSource"> 
    <bean class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
     <property name="connectionProperties"> 
     <props> 
      <prop key="dynamicClass">com.arjuna.ats.internal.jdbc.drivers.PropertyFileDynamicClass</prop> 
      <prop key="password"></prop> 
      <prop key="user">sa</prop> 
     </props> 
     </property> 
     <property name="driverClassName" value="com.arjuna.ats.jdbc.TransactionalDriver"/> 
     <property name="url" value="jdbc:arjuna:database.properties"/> 
    </bean> 
    </property> 
    <property name="packagesToScan" value="org.example.domain"/> 
</bean> 

<bean class="org.springframework.transaction.jta.JtaTransactionManager" id="transactionManager"> 
    <property name="transactionManager"> 
    <bean class="com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionManagerImple"/> 
    </property> 
    <property name="userTransaction"> 
    <bean class="com.arjuna.ats.jta.UserTransaction" factory-method="userTransaction"/> 
    </property> 
</bean> 

<transaction:annotation-driven/> 

但是,試圖運行該應用程序引發以下錯誤:

java.lang.IllegalStateException: Failed to load ApplicationContext 
Caused by: javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory 
Caused by: org.hibernate.exception.GenericJDBCException: Unable to open JDBC Connection for DDL execution 
Caused by: java.sql.SQLException: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial 
    at com.arjuna.ats.internal.jdbc.IndirectRecoverableConnection.createDataSource(IndirectRecoverableConnection.java:361) 
    at com.arjuna.ats.internal.jdbc.IndirectRecoverableConnection.<init>(IndirectRecoverableConnection.java:109) 
    at com.arjuna.ats.internal.jdbc.ConnectionImple.<init>(ConnectionImple.java:107) 
    at com.arjuna.ats.internal.jdbc.ConnectionManager.create(ConnectionManager.java:110) 
    at com.arjuna.ats.jdbc.TransactionalDriver.connect(TransactionalDriver.java:87) 
    at java.sql.DriverManager.getConnection(DriverManager.java:664) 
    at java.sql.DriverManager.getConnection(DriverManager.java:208) 
    at org.springframework.jdbc.datasource.DriverManagerDataSource.getConnectionFromDriverManager(DriverManagerDataSource.java:153) 
    at org.springframework.jdbc.datasource.DriverManagerDataSource.getConnectionFromDriver(DriverManagerDataSource.java:144) 
    at org.springframework.jdbc.datasource.AbstractDriverBasedDataSource.getConnectionFromDriver(AbstractDriverBasedDataSource.java:196) 
    at org.springframework.jdbc.datasource.AbstractDriverBasedDataSource.getConnection(AbstractDriverBasedDataSource.java:159) 
    at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122) 
    at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess.obtainConnection(JdbcEnvironmentInitiator.java:180) 
    at org.hibernate.resource.transaction.backend.jta.internal.DdlTransactionIsolatorJtaImpl.prepare(DdlTransactionIsolatorJtaImpl.java:49) 
    ... 60 more 
Caused by: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial 
    at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:662) 
    at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:313) 
    at javax.naming.InitialContext.getURLOrDefaultInitCtx(InitialContext.java:350) 
    at javax.naming.InitialContext.lookup(InitialContext.java:417) 
    at com.arjuna.ats.internal.jdbc.IndirectRecoverableConnection.createDataSource(IndirectRecoverableConnection.java:346) 

似乎沒有被任何關於JNDI是否必須運行JBossTS的文檔,以及如何在不使用JavaEE容器的獨立應用程序中配置。

一個示例應用程序is available on Github萬一需要完整的配置和源代碼。通過運行Maven測試可以看到問題mvn test -D"spring.profiles.active=jbossts"

回答

1
  1. 更換<prop key="dynamicClass"><prop key="DYNAMIC_CLASS">
  2. 指定屬性與target/classes
  3. 文件使用H2文件數據庫,而不是存儲

欲瞭解更多信息,你可以看到narayana.io

+0

感謝@ AmosFeng,你使用'DYNAMIC_CLASS'而不是'dynamicClass'的建議奏效了。 – manish