9

我在无状态 EJB 中使用了 2 个 PU,它们中的每一个都在一个方法上调用:

@PersistenceContext(unitName="PU")
private EntityManager em;
@PersistenceContext(unitName="PU2")
private EntityManager em2;

@TransactionAttribute(TransactionAttributeType.REQUIRES_NEW )
public void getCandidates(final Integer eventId) throws ControllerException {
    ElectionEvent electionEvent = em.find(ElectionEvent.class, eventId);
    ...
    Person person = getPerson(candidate.getLogin());
    ...
}

@TransactionAttribute(TransactionAttributeType.REQUIRES_NEW )
private Person getPerson(String login) throws ControllerException {
    Person person = em2.find(Person.class, login);
    return person;
}

这些方法使用 REQUIRES_NEW 事务注释以避免此异常。当我从 javaFX 小程序调用这些方法时,一切都按预期工作。现在我试图从 JAX-RS webservice 调用它们(我没有看到任何逻辑差异,因为在这两种情况下,ejb 都是在初始上下文中查找的)并且我不断收到这个异常。当我在 glassfish 2.1 连接池中设置 XADatasource 时,我在 em2 上遇到了空指针异常。

任何想法接下来要尝试什么?

问候

4

3 回答 3

7

行,

现在解决了。我会分享以防有人遇到类似的事情。整个问题在于 netbeans 部署。它们会覆盖 glassfish 连接池中的设置,当您在运行时正确设置它们时,您会得到 npe 或缺少密码的傻东西。编辑它的地方是sun-resources.xml。XML 元素具有属性 datasource-classname 和 rs-type。对于 Derby 数据库,需要做的是:

<jdbc-connection-pool ... 
        datasource-classname="org.apache.derby.jdbc.ClientXADataSource" 
        res-type="javax.sql.XADataSource">
   ...
</jdbc-connection-pool>

现在就像一个魅力。

于 2010-04-24T22:03:41.593 回答
6

我在无状态 EJB 中使用 2 个 PU,每个 PU 都在一个方法上调用

确实。但是您从第一个方法调用第二个方法,因此您正在执行分布式事务并且您需要为此使用 XA(至少对于其中一个资源,因为 GlassFish 支持最后一个代理优化,允许涉及一个非 XA资源)。换句话说,将您的数据源之一设置为 aXADataSource是可行的方法。

如果您在执行此操作时遇到错误,请添加有关您所做的确切 操作和堆栈跟踪的详细信息。

于 2010-04-21T23:14:07.507 回答
2

从第一个调用第二个方法时,它不是 EJB 方法调用。它将它视为只是一个常规的方法调用,而不是查看@TransactionAttribute. 如果你想调用同一个 EJB,你可以注入SessionContext和调用getBusinessObject。然后在返回的 EJB 上调用该方法。

于 2011-12-21T16:22:02.120 回答