OpenEJB с Tomcat, Hibernate и JPA
Вопрос
Я использую OpenEJB 3.1.3, встроенный в Tomcat 5.5.26, и использую hibernate 3.6 в качестве поставщика JPA.
Вот мой файл persistence.xml:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.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_1_0.xsd">
<persistence-unit name="manager1" transaction-type="JTA">
<!-- provider is optional if you work with only 1 JPA provider -->
<!--
<provider>org.hibernate.ejb.HibernatePersistence</provider>
-->
<jta-data-source>java:/DefaultDS</jta-data-source>
<!--
<properties>
<property name="hibernate.ejb.cfgfile" value="/hibernate.cfg.xml" />
</properties>
-->
</persistence-unit>
</persistence>
Вот мой код:
@Stateless
public class MapSearchManager implements MapSearchLocal, MapSearchRemote {
@PersistenceContext
private EntityManager em;
...
@TransactionAttribute(TransactionAttributeType.REQUIRED)
public int queryDataSelectionNumRecords(MapSearchParamBean paramBean) {
Criteria c = createCriteria(paramBean);
c.setProjection(Projections.rowCount());
List l = c.list();
...
}
...
}
Когда я запускаю tomcat с OpenEJB и архивами войны моего приложения, развертывание завершилось неудачей с трассировкой стека исключений:
2010-10-27 18:13:35,374 - ERROR - Unable to deploy collapsed ear in war /wma: Exception: Creating application failed: C:\apache-tomcat-5.5.26\webapps\wma: javax/persistence/spi/ProviderUtil
org.apache.openejb.OpenEJBException: Creating application failed: C:\apache-tomcat-5.5.26\webapps\wma: javax/persistence/spi/ProviderUtil
at org.apache.openejb.assembler.classic.Assembler.createApplication(Assembler.java:666)
at org.apache.openejb.assembler.classic.Assembler.createApplication(Assembler.java:449)
at org.apache.openejb.tomcat.catalina.TomcatWebAppBuilder.start(TomcatWebAppBuilder.java:249)
at org.apache.openejb.tomcat.catalina.GlobalListenerSupport.lifecycleEvent(GlobalListenerSupport.java:58)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4148)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:760)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:740)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:544)
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:926)
at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:889)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1149)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1022)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:736)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1014)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
at org.apache.catalina.core.StandardService.start(StandardService.java:448)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
at org.apache.catalina.startup.Catalina.start(Catalina.java:552)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)
Caused by: java.lang.NoClassDefFoundError: javax/persistence/spi/ProviderUtil
at java.lang.Class.getDeclaredConstructors0(Native Method)
at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)
at java.lang.Class.getConstructor0(Class.java:2699)
at java.lang.Class.newInstance0(Class.java:326)
at java.lang.Class.newInstance(Class.java:308)
at org.apache.openejb.assembler.classic.PersistenceBuilder.createEntityManagerFactory(PersistenceBuilder.java:179)
at org.apache.openejb.assembler.classic.Assembler.createApplication(Assembler.java:489)
... 27 more
После поиска я нашел класс javax/persistence/spi/ProviderUtil
является частью спецификации Java EE 6/JPA 2.0, которая не поддерживается OpenEJB.Но я не думаю, что в своем приложении я использую JPA 2.0.Я специально упоминаю в файле persistence.xml версии 1.0.Я знаю, что Hibernate 3.6 поддерживает JPA 2.0.Я не знаю, является ли API Criteria Hibernate частью JPA 2.0, но это не должно вызывать проблем, поскольку я специально упомянул версию 1.0 в файле persistence.xml.
Спасибо за помощь.
С уважением
Воля
Решение
При поиске я обнаружил, что класс javax/persistence/spi/ProviderUtil является частью спецификации Java EE 6/JPA 2.0.
Это верно.
который не поддерживается OpenEJB.
Еще нет.Это отслеживается ОПЕНЕЙБ-1236.
Но я не думаю, что в своем приложении я использую JPA 2.0.
Независимо от того, используете ли вы функции JPA 2.0 или нет, некоторые изменения в различных интерфейсах требуют явной поддержки со стороны контейнеров.
Я специально упоминаю в файле persistence.xml версии 1.0.
Это не имеет никакого значения, контейнер все еще пытается загрузить реализацию JPA 2.0.
Я не знаю, является ли API критериев гибернации частью JPA 2.0.
JPA 2.0 имеет новый API критериев, но API критериев Hibernate часть...Спящий режим.Насколько я вижу, вы используете Hibernate API, и поэтому я предлагаю использовать его реализацию JPA 1.0, т.е.Hibernate EntityManager 3.4.0.GA и его зависимости, предоставляющие этот API.В любом случае вам не нужен JPA 2.0.
В сети не так уж много информации о сопоставлении версий hibernate-jpa.То есть вы имеете в виду, что проекты Hibernate EntityManager и Annotations являются реализацией спецификации JPA 1.0, а проект Hibernate Core содержит базовый спящий режим (вне JPA) и реализацию JPA 2.0?
Hibernate EntityManager — это проект, обеспечивающий реализацию JPA.
- Hibernate EntityManager 3.4.0.GA — это реализация JPA 1.0.
- Hiberante EnittyManager 3.5+ — это реализация JPA 2.0.
Он опирается на Hibernate Core (и некоторые другие библиотеки).Чтобы использовать Hibernate EntityManager 3.4.0.GA, вам потребуется следующее:
org.hibernate:hibernate-entitymanager:jar:3.4.0.GA:compile +- org.hibernate:ejb3-persistence:jar:1.0.2.GA:compile +- org.hibernate:hibernate-commons-annotations:jar:3.1.0.GA:compile +- org.hibernate:hibernate-annotations:jar:3.4.0.GA:compile +- org.hibernate:hibernate-core:jar:3.3.0.SP1:compile | +- antlr:antlr:jar:2.7.6:compile | \- commons-collections:commons-collections:jar:3.1:compile +- org.slf4j:slf4j-api:jar:1.5.10:compile +- dom4j:dom4j:jar:1.6.1:compile | \- xml-apis:xml-apis:jar:1.0.b2:compile +- javax.transaction:jta:jar:1.1:compile \- javassist:javassist:jar:3.4.GA:compile
Я использую Maven, поэтому мне просто нужно объявить зависимость от hibernate-entitymanager, но если вы этого не сделаете, получите комплект от SourceForge.