【问题标题】:TransactionRequiredException with WeblogicJtaTransactionManagerWeblogicJtaTransactionManager 的 TransactionRequiredException
【发布时间】:2013-12-21 16:57:32
【问题描述】:

我正在尝试在我的应用程序中使用分布式事务。为此,我配置了 WeblogicJtaTransactionManager(由 spring 提供)来管理我的分布式事务。但它似乎交易没有开始。在运行更新查询时得到以下异常:

 Executing an update/delete query; nested exception is
 javax.persistence.TransactionRequiredException: Executing an update/delete query  

我的应用程序上下文:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
    http://www.jasypt.org/schema/encryption http://www.jasypt.org/schema/encryption/jasypt-spring31-encryption-1.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd">

<!-- <tx:jta-transaction-manager /> -->
<tx:annotation-driven  transaction-manager="transactionManager" proxy-target-class="true"/> 

<context:component-scan base-package="com.myapp">
    <context:exclude-filter type="regex" expression="com.myapp.controllers"/>
</context:component-scan>

   <jee:jndi-lookup jndi-name="jdbc/myDataSource" id="dataSource"/>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="jtaDataSource" ref="dataSource" />
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
    </property>
    <property name="jpaDialect">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />
    </property>
    <property name="packagesToScan" value="com.myapp.domain" />
    <property name="jpaProperties">
        <props>
            <prop key="javax.persistence.sharedCache.mode">NONE</prop>
            <prop key="hibernate.dialect">${app.db.dailect}</prop>
            <prop key="initialSize">${app.db.minpoolsize}</prop>
            <prop key="maxActive">${app.db.maxpoolsize}</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.max_fetch_depth">0</prop>
            <prop key="hibernate.query.substitutions">true=1, false=0</prop>
            <prop key="hibernate.generate_statistics">false</prop>
            <prop key="javax.persistence.query.timeout">600000</prop>
            <prop key="hibernate.transaction.factory_class">org.hibernate.engine.transaction.internal.jta.JtaTransactionFactory</prop>
            <prop key="hibernate.transaction.jta.platform">org.hibernate.service.jta.platform.internal.WeblogicJtaPlatform</prop>
        </props>
    </property>
</bean>
<!-- <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory" />
    <property name="jpaDialect">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />
    </property>
</bean> -->

<bean id="transactionManager" class="org.springframework.transaction.jta.WebLogicJtaTransactionManager"  >
    <property name="transactionManagerName" value="javax.transaction.TransactionManager"/>
</bean>
<jpa:repositories base-package="com.myapp.repos" factory-class="com.myapp.repos.BaseRepositoryFactoryBean" 
entity-manager-factory-ref="entityManagerFactory"/>

感谢任何帮助。

【问题讨论】:

  • 正如 Abhijeet 建议的那样,我在 weblogic 中创建了数据源并使用 jndi 引用它们。但我仍然遇到同样的错误。已更新配置文件
  • 你能粘贴你修改过的XML吗?
  • 当前 applicationcontext.xml 是更新的。我使用 jee:jndi-lookup 标签进行 jndi 查找

标签: spring hibernate jta distributed-transactions weblogic12c


【解决方案1】:

这是您的数据源的问题。您正在使用不受 weblogic 管理的 ComboPooledDataSource。

【讨论】:

  • 那么我应该使用什么数据源??
  • 你必须在weblogic中配置一个数据源并使用JNDI查找
  • 对服务器容器的依赖是不是有点太多了?没有更好的方法吗?我也通过eclipse ide插件运行weblogic。所以我不确定我可以在 weblogic 中配置数据源
  • 好的。让我问你为什么要使用分布式容器管理事务?如果不是分布式的,你可以很好地使用 LocalEntityManagerFactoryBean。
  • 它是分布式的。那就是我想使用它。我访问了另外两个数据库。目前我只配置了一个并试图让事情正常进行。我需要再配置两个数据库。
猜你喜欢
  • 2016-11-12
  • 1970-01-01
  • 1970-01-01
  • 2019-11-01
  • 2020-01-28
  • 2015-12-19
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多