我有一个 JAX-RS Restful 服务,需要访问 MySQL 数据库。我正在尝试使用 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>
如有任何帮助,我们将不胜感激
最佳答案
好的,持久化单元可以配置为两种模式:RESOURCE_LOCAL 和 JTA。
例如:
<persistence-unit name="beta.example.services" transaction-type="JTA">
VS
<persistence-unit name="beta.example.services" transaction-type="RESOURCE_LOCAL">
JTA 是默认值。仅当使用“RESOURCE_LOCAL”时才会读取“javax.persistence.jdbc.*”等属性。使用JTA时,会使用glassfish的事务管理器。这意味着在这种情况下您必须指定 JNDI 名称,如下所示:
<jta-data-source>youJNDIName</jta-data-source>
我认为可能发生的情况是您使用默认的“JTA”事务类型,但由于您没有指定任何 jta 数据源,它可能会尝试使用 glassfish 默认类型(指向 derby)。
Persistence unit as RESOURCE_LOCAL or JTA?
http://openejb.apache.org/jpa-concepts.html
看看您如何使用实体管理器,将事务类型设置为 RESOURCE_LOCAL 似乎是适合您的解决方案。
关于java - 注入(inject)的实体管理器未使用正确的持久性单元,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10580001/