2012-07-12 3 views
2

JBoss AS 7.1.1.Final의 MongoDB에 대해 EclipseLink NoSql Persistence를 사용하려고합니다. EclipseLink를 통한 MongoDB 지속성 NoSql JBoss AS 7.1.1. 최종

내가 같은 EntityManager를 사용하는 것을 시도하고있다 :

EntityManager em = Persistence.createEntityManagerFactory("mongo") 
      .createEntityManager(); 

    Model m = new Model(); 
    em.getTransaction().begin(); 
    em.persist(m); 
    em.getTransaction().commit(); 

것은 여기에 내가 지시가 here를 지정하여 설치 내 보스로는 EclipseLink 모듈을 추가 내 persistence.xml을

<?xml version="1.0" encoding="UTF-8" ?> 
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0"> 
    <persistence-unit name="mongo" transaction-type="RESOURCE_LOCAL"> 
     <class>com.Model</class> 
     <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider> 
     <properties> 
     <property name="eclipselink.ddl-generation" value="dorop-and=create=tables" /> 
      <property name="eclipselink.target-database" 
       value="org.eclipse.persistence.nosql.adapters.mongo.MongoPlatform" /> 
      <property name="eclipselink.nosql.connection-spec" 
       value="org.eclipse.persistence.nosql.adapters.mongo.MongoConnectionSpec" /> 
      <property name="eclipselink.logging.level" value="FINEST" /> 

     </properties> 
    </persistence-unit> 
</persistence> 

입니다. 또한 EclipseLink modules.xml에 javax.resource.jar을 종속성으로 추가하고 javax.resource 용 JBoss 모듈을 만들었습니다. 모듈을 JBoss에 추가하지 않아도되고, 대신 전쟁에 참여하는 것을 피할 수있는 방법이 있다면 알려 주시기 바랍니다.

내가 직면하고있는 현재의 문제는 다음과 같습니다. javax.resource.jar (이전에 다른 오류가 발생했습니다) 및 누락 된 javax.resource.cci.ConnectionFactory 클래스 거기에있다.

1:35,286 ERROR [org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/barebones].[com.Servlet]] (http-localhost-127.0.0.1-8080-1) Servlet.service() for servlet com.Servlet threw exception: javax.persistence.PersistenceException: java.lang.NoClassDefFoundError: javax/resource/cci/ConnectionFactory 
    at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:602) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getDatabaseSession(EntityManagerFactoryDelegate.java:186) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.createEntityManagerImpl(EntityManagerFactoryDelegate.java:278) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManagerImpl(EntityManagerFactoryImpl.java:304) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:282) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at com.Servlet.doGet(Servlet.java:22) [classes:] 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:734) [jboss-servlet-api_3.0_spec-1.0.0.Final.jar:1.0.0.Final] 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:847) [jboss-servlet-api_3.0_spec-1.0.0.Final.jar:1.0.0.Final] 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:329) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:248) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) [jbossweb-7.0.13.Final.jar:] 
    at org.jboss.as.jpa.interceptor.WebNonTxEmCloserValve.invoke(WebNonTxEmCloserValve.java:50) [jboss-as-jpa-7.1.1.Final.jar:7.1.1.Final] 
    at org.jboss.as.web.security.SecurityContextAssociationValve.invoke(SecurityContextAssociationValve.java:153) [jboss-as-web-7.1.1.Final.jar:7.1.1.Final] 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:368) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:671) [jbossweb-7.0.13.Final.jar:] 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:930) [jbossweb-7.0.13.Final.jar:] 
    at java.lang.Thread.run(Thread.java:662) [rt.jar:1.6.0_31] 
Caused by: java.lang.NoClassDefFoundError: javax/resource/cci/ConnectionFactory 
    at org.eclipse.persistence.eis.EISConnectionSpec.connectToDataSource(EISConnectionSpec.java:146) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.nosql.adapters.mongo.MongoConnectionSpec.connectToDataSource(MongoConnectionSpec.java:150) [org.eclipse.persistence.nosql_2.4.0.v20120608-r11652.jar:] 
    at org.eclipse.persistence.eis.EISLogin.connectToDatasource(EISLogin.java:73) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.databaseaccess.DatasourceAccessor.connectInternal(DatasourceAccessor.java:330) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.databaseaccess.DatasourceAccessor.connect(DatasourceAccessor.java:418) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.sessions.server.ConnectionPool.buildConnection(ConnectionPool.java:216) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.sessions.server.ConnectionPool.startUp(ConnectionPool.java:504) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.sessions.server.ServerSession.connect(ServerSession.java:484) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.sessions.DatabaseSessionImpl.login(DatabaseSessionImpl.java:734) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerFactoryProvider.login(EntityManagerFactoryProvider.java:215) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:542) [eclipselink-2.4.0.jar:2.4.0.v20120608-r11652] 
    ... 21 more 
Caused by: java.lang.ClassNotFoundException: javax.resource.cci.ConnectionFactory from [Module "org.eclipse.persistence:main" from local module loader @2b76e552 (roots: /usr/jboss/jboss-as-7.1.1.Final/modules)] 
    at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:190) 
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassUnchecked(ConcurrentClassLoader.java:468) 
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:456) 
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:423) 
    at org.jboss.modules.ConcurrentClassLoader.performLoadClass(ConcurrentClassLoader.java:398) 
    at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:120) 
    ... 32 more 
+0

최근에 persistence.xml에 을 추가하고 JBoss 모듈에 eclipselink.jar를 추가했습니다. -로드 블록이 업데이트되었습니다. –

+0

오류는 클래스를로드 할 때 ResourceException 클래스를 찾을 수 없기 때문입니다. 이는 EclipseLink가 애플리케이션 클래스 로더를 사용하여 "MongoPlatform"클래스를로드하려고 시도하고 나서이를 사용하여 새로운 인스턴스를 생성 할 때 예외가 발생하기 때문입니다. 불행히도 누락 된 ResourceException 클래스는 실제 예외를 throw 할 수 없음을 의미합니다. javax.resource가 EclipseLink 모듈 종속성으로 추가되었는지 확인하십시오. – Chris

+0

@Chris - Man ... 지난 주에 했었지만 javax/resource 용 modules.xml을 사용하지 않았습니다. 업데이트 된로드 블록 및 추가 단계. 감사! –

답변

0

동일한 사용법이 있습니다. org.eclipse.persistence의 module.xml에 "< module name ="javax.resource.api "/>" 을 추가하십시오.

그것은 나를 위해 일했습니다.