我正在尝试在 OpenEJB 3.1.4 + Tomcat 6 中部署应用程序。该应用程序在 JBoss 中部署正常,但我想让它在 OpenEJB 中运行。
基本上,我想知道如何配置我的数据源并使用 EAR for OpenEJB 部署它。
现在:
EJB 可以在 OpenEJB 的 JNDI 浏览器中找到,但 hibernate 似乎没有找到数据源(它无法更新数据库模式)——来自标准输出:
org.hibernate.tool.hbm2ddl.SchemaExport execute INFO: Running hbm2ddl schema export
org.hibernate.tool.hbm2ddl.SchemaExport execute INFO: exporting generated schema to database
org.hibernate.tool.hbm2ddl.SchemaExport create GRAVE: Unsuccessful: create table Answer ([...])
我persistence.xml
对我的数据源的看法:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence"
[...]
<persistence-unit name="myapp">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>java:/myapp_mysql</jta-data-source>
我试图包含一个数据源文件,如src/main/application/mysql-ds.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<datasources>
<local-tx-datasource>
<jndi-name>myapp_mysql</jndi-name>
<connection-url>jdbc:mysql://hostname:3306/my_app</connection-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<user-name>user</user-name>
<password>password</password>
甚至另一个像src/main/application/openejb.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<openejb>
<Connector id="myapp_mysql">
JdbcDriver = com.mysql.jdbc.Driver
JdbcUrl = jdbc:mysql://hostname:3306/my_app
UserName = user
Password = password
</Connector>
</openejb>
但是我的应用容器似乎没有加载/考虑它们。有任何想法吗?