繁体   English   中英

在JBoss / WildFly中,我应该在数据源上启用JTA以与JPA一起使用吗?

[英]In JBoss/WildFly should I enable JTA on data source to use with JPA?

在JBoss / WildFly中,配置数据源时,有一个JTA选项,默认情况下禁用:

<datasource jta="false" jndi-name="java:/wt/testds" pool-name="testds" enabled="true" use-ccm="false">  
...  
</datasource> 

现在我想使用JTA事务类型将此数据源与JPA关联:

<?xml version="1.0" encoding="UTF-8"?>  
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence"  
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">  
    <persistence-unit name="test" transaction-type="JTA">  
        <jta-data-source>java:/wt/testds</jta-data-source>  
    </persistence-unit>  
</persistence>  

我是否还需要在数据源上启用JTA?

是的,当然如果你想拥有jta交易,你需​​要在数据源上启用JTA!

您的XML / JBoss / Wildfly配置文件如下所示:

<datasource jta="true" ...

在我们的webapp持久性单元中,数据源如下所示:

<jta-data-source>java:jboss/datasources/CoreDS</jta-data-source>

transaction-type="JTA"不是必需的,至少在我的设置中没有(Wildfly 8.1)。

在您的Java代码中,您可以像这样使用事务:

@TransactionManagement(TransactionManagementType.CONTAINER) // class level
public class ...
...
    @PersistenceContext(unitName = "CoreJPA")
    EntityManager em;

    @Resource
    private EJBContext ejbContext;
...
@TransactionAttribute(TransactionAttributeType.REQUIRES_NEW) // method level
public void doSomething(...)

如果你需要回滚,你可以这样做:

try {
  ...
} catch (Throwable t) {
    log.error("Exception in create work order: " + t.getMessage());
    ejbContext.setRollbackOnly();
    throw t;
}

有很多关于此的资源可以通过Google找到。

我刚刚遇到了与此问题相关的问题。

我正在运行一个容器管理事务,涉及大约20,000个插入MySQL数据库。

交易随机失败,有时在大约3,500次插入后,其他时间大约6,000次插入后等。

经过调查,我发现WildFly数据源定义中的JTA选项设置为false。

将此设置更改为true可以解决问题,因此我同意@ user3472929在数据源定义中应将JTA设置为true,除非您有某些特定原因不这样做。

我认为你应该使用jta。 如果在容器配置文件中将jta设置为false,则JPA将禁用jta,因此JPA的事务类型将为“RESOURCE_LOCAL”,这会产生一些令人讨厌的副作用。 顺便说一句,默认情况下,jta在容器配置文件中为true。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM