【发布时间】:2014-09-26 23:14:41
【问题描述】:
我一直试图让我的 JPA (openJPA) 应用程序使用非 jta 数据源与 Tomcat 一起工作。
我使用的是 maven,没有 IDE。只是在 windows 上使用 vi,主要是为了了解事情是如何真正工作并结合在一起的
这是我得到的错误(我在 SO 上研究过类似的问题,但无法找到解决方法)
Caused by: java.lang.RuntimeException: <openjpa-2.3.0-r422266:1540826 fatal user error> org.apache.openjpa.persistence.ArgumentException: The persistence provider is attempting to use properties in the persistence.xml file to resolve the data source. A Java Database Connectivity (JDBC) driver or data source class name must be specified in the openjpa.ConnectionDriverName or javax.persistence.jdbc.driver property. The following properties are available in the configuration: "org.apache.openjpa.jdbc.conf.JDBCConfigurationImpl@442ce698".
这是我的 persistence.xml 文件
<?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="CricketScorer" transaction-type="RESOURCE_LOCAL">
<provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider>
<non-jta-data-source>java:/comp/env/jdbc/scoringdb</non-jta-data-source>
<class>com.mantr.cricket.scorer.server.persistence.entities.Account</class>
<class>com.mantr.cricket.scorer.server.persistence.entities.Delivery</class>
<class>com.mantr.cricket.scorer.server.persistence.entities.DeliveryPK</class>
<class>com.mantr.cricket.scorer.server.persistence.entities.Match</class>
<class>com.mantr.cricket.scorer.server.persistence.entities.Player</class>
<class>com.mantr.cricket.scorer.server.persistence.entities.Team</class>
</persistence-unit>
</persistence>
这是 Tomcat 的 context.xml 文件
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<!-- JDBC Data source for the scoring database -->
<Resource name="jdbc/scoringdb"
auth="Container"
type="javax.sql.DataSource"
username="b888446f2789ce"
password="28fa221e"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://us-cdbr-east-06.cleardb.net/heroku_17744ef452a6a8d"
maxActive="10"
maxIdle="4"/>
</Context>
还有 Web.xml 文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<servlet>
<servlet-name>cxf</servlet-name>
<display-name>cxf</display-name>
<description>Apache CXF Endpoint</description>
<servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>cxf</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
<resource-ref>
<description>Scoring Database</description>
<res-ref-name>jdbc/scoringdb</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
这在我尝试使用 JNDI 初始上下文打开连接时有效。所以JNDI数据源配置正确,我认为
【问题讨论】:
-
只是一个建议,因为我不使用 Tomcat,而是使用 Glassfish。你
persistence.xml中定义的数据源不应该只是<non-jta-data-source>jdbc/scoringdb</non-jta-data-source>吗?由于这是您web.xml的资源名称,因此java:/comp/env/...似乎是多余的并且可能是错误的。毕竟容器的资源名称只是jdbc/scoringdb。 -
谢谢@dic19。我试过你推荐的。同样的错误...