2012-05-14 38 views
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 

这里是RESTful服务:

@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> 

任何帮助,将不胜感激

+0

我会检查数据库连接。您是否可以使用任何其他JDBC工具(如DbVisualizer)从与应用程序相同的机器连接到数据库? – DRCB

+0

我目前在同一台机器上运行应用程序并且能够连接。我最初使用eclipse向导进行设置(并且仍可以ping数据库)。奇怪的部分是,它甚至不像它试图连接到正确的数据库。它试图连接1527端口(我相信这是德比)。我还检查了发布时,persistence.xml文件存在于'/ WEB-INF/classes/META-INF' –

+0

哪个应用服务器?你在服务器配置中配置了数据源吗? – zeller

回答

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时,将使用玻璃鱼的交易经理。也就是说,在这种情况下,你必须像这样指定JNDI名称:

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

我想可能发生的是,你使用默认的“JTA”事务型,但因为你不指定任何的JTA数据源,它可能会尝试使用玻璃鱼默认的一个(指向德比)。

Persistence unit as RESOURCE_LOCAL or JTA?

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

看你如何使用实体管理器,设置交易类型RESOURCE_LOCAL似乎是你的解决方案。

相关问题