2

我有一个需要访问 MySQL 数据库的 JAX-RS restful 服务。我正在尝试使用 CDI 和实体管理器来做到这一点。但是,当我发布应用程序时,似乎使用了不正确的持久性单元(它试图连接端口 1527 而不是 3306)。

try/catch 捕获的异常是:

javax.servlet.ServletException: 
javax.persistence.PersistenceException: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.3.0.v20110604-r9504): 
org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: 
java.sql.SQLException: 
Error in allocating a connection. Cause: Connection could not be allocated because: 
java.net.ConnectException : Error connecting to server localhost on port 1527 with message Connection refused: connect.
Error Code: 0

这是宁静的服务:

@Path("/databases")
@Stateless
public class DatabaseResource {

    @PersistenceUnit(unitName = "beta.example.services")
    EntityManagerFactory entityManagerFactory;

    @GET
    @Produces(MediaType.APPLICATION_JSON)
    public Response list() {
        try {

            EntityManager entityManager = entityManagerFactory.createEntityManager();
            Connection connection = entityManager.unwrap(java.sql.Connection.class);

            ...

            return Response.ok().build();

        } catch (SchemaCrawlerException e) {
            return Response.status(500).entity(e.getMessage()).build();
        }
    }
}

持久化单元(位于 src/META-INF):

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
    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">
    <persistence-unit name="beta.example.services">
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <properties>
            <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
            <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/" />
            <property name="javax.persistence.jdbc.user" value="test" />
            <property name="javax.persistence.jdbc.password" value="test" />
        </properties>
    </persistence-unit>
</persistence>

任何帮助,将不胜感激

4

1 回答 1

2

好的,可以在两种模式下配置持久性单元:RESOURCE_LOCAL 和 JTA。
前任:

<persistence-unit name="beta.example.services" transaction-type="JTA">

VS

<persistence-unit name="beta.example.services" transaction-type="RESOURCE_LOCAL">

JTA 是默认值。像“javax.persistence.jdbc.*”这样的属性只有在使用“RESOURCE_LOCAL”时才会被读取。使用 JTA 时,会用到 glassfish 的事务管理器。这意味着在这种情况下,您必须像这样指定 JNDI 名称:

<jta-data-source>youJNDIName</jta-data-source>

我认为可能发生的是您使用默认的“JTA”事务类型,但由于您没有指定任何 jta 数据源,它可能会尝试使用 glassfish 默认的一个(指向 derby)。

持久性单元为 RESOURCE_LOCAL 还是 JTA?

http://openejb.apache.org/jpa-concepts.html

查看您如何使用实体管理器,将事务类型设置为 RESOURCE_LOCAL 似乎是您的解决方案。

于 2012-07-25T15:13:01.950 回答