Как мне объявить мой источник данных в OpenEJB? - PullRequest
1 голос
/ 04 марта 2011

Я пытаюсь развернуть приложение в OpenEJB 3.1.4 + Tomcat 6. Это приложение развертывается нормально в JBoss, но я хочу, чтобы оно работало в OpenEJB.

По сути, я хотел бы знаю, как настроить мой источник данных и развернуть его с EAR для OpenEJB .

Прямо сейчас:

EJB можно найти в браузере JNDI OpenEJB, но Hibernate некажется, найти источник данных (он не может обновить схему базы данных) - из stdout:

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 ([...])

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

Но, похоже, ни один из них не загружен / не принят во вниманиемой контейнер приложений.Есть идеи?

Ответы [ 2 ]

3 голосов
/ 04 марта 2011

Нашел это.На самом деле я запутался с развертыванием EJB, и это был настоящий контейнер приложения: OpenEJB - это контейнер приложения, но сам он развернут как веб-приложение в Tomcat .

Сначала настройте свой PersistenceUnit в 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>myapp_mysql</jta-data-source>

Затем объявите свой источник данных в конфигурационном файле OpenEJB tomcat\conf\openejb.xml

<Resource id="myapp_mysql" type="DataSource">
  JdbcDriver  com.mysql.jdbc.Driver
  JdbcUrl   jdbc:mysql://localhost:3306/my_app
  UserName   user
  Password  password
  JtaManaged true
</Resource>
0 голосов
/ 04 марта 2011

Это потому, что вы используете JBoss-файл развертывания (mysql-ds.xml) для приложения, развернутого в Tomcat.Для tomcat вам понадобится другой файл.Смотрите это:

http://tomcat.apache.org/tomcat-6.0-doc/jndi-resources-howto.html#JDBC_Data_Sources

Не уверен насчет части OpenEJB, так как у меня нет опыта работы с ней.

...