2010-10-28 74 views
5

我使用嵌入在Tomcat 5.5.26中的OpenEJB 3.1.3,並使用hibernate 3.6作爲JPA提供程序。使用Tomcat和Hibernate和JPA的OpenEJB

這裏是我的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是Jav的一部分EE 6/JPA 2.0規範,OpenEJB不支持。但我不認爲在我的應用程序中使用任何JPA 2.0。我特別提到了1.0的persistence.xml。我知道hibernate 3.6支持JPA 2.0。我不知道hibernate的Criteria API是否是JPA 2.0的一部分,但是不應該導致這個問題,因爲我在persistence.xml中特別提到了1.0。

謝謝你的幫助。

問候

威爾

回答

4

在搜索,我發現的Java EE 6/JPA 2.0規範

的類的javax /持久/ SPI/ProviderUtil是一部分。這是正確的。

這是OpenEJB不支持的。

還沒有。這跟蹤OPENEJB-1236

但是,我認爲在我的應用我使用任何JPA 2.0

無論您使用JPA 2.0功能,或者不,在各種接口的一些變化需要從容器中的明確支持。

我在persistence.xml中特別提到了1.0。

這沒有什麼區別,容器仍在嘗試加載JPA 2.0實現。

我不知道Hibernate的標準API是JPA 2.0

部分JPA 2.0有一個新的Criteria API,但Hibernate的標準API是... Hibernate的一部分。從我所看到的,您使用的是Hibernate API,因此我的建議是使用其JPA 1.0實現 - 即提供此API的Hibernate EntityManager 3.4.0.GA及其依賴項。無論如何,你不需要JPA 2.0。


沒有關於匹配的Hibernate JPA版本的淨多的信息。那麼你的意思是Hibernate EntityManager和Annotations項目是JPA 1.0規範的實現,而Hibernate Core項目包含核心hibernate(非JPA impl)和JPA 2.0 impl?

Hibernate EntityManager是提供JPA實現的項目。

  • 休眠的EntityManager 3.4.0.GA是JPA 1.0實施
  • 的Hiberante EnittyManager 3.5+是JPA 2.0實施

它依賴於休眠核心(和其他一些庫)。使用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,所以我只需要申報的休眠,EntityManager的依賴,但如果你不這樣做,得到bundle from SourceForge

+0

謝謝帕斯卡。網絡上沒有太多有關hibernate-jpa版本匹配的信息。那麼你的意思是Hibernate EntityManager和Annotations項目是JPA 1.0規範的實現,而Hibernate Core項目包含核心hibernate(非JPA impl)和JPA 2.0 impl?再次感謝。 – 2010-10-29 02:11:44