JBoss AS 7 Fehler: KRIEG-Bereitstellung erfolgreich ist, wird der EAR-Bereitstellung schlägt fehl
Nehme ich die gleiche genau die gleiche web-Anwendung und installieren Sie es wie ein KRIEG ohne Probleme. Allerdings gleichen Anwendung eingesetzt als OHR schlägt. Gleiche Dateien, nur anders Bereitstellung. Ersten, Blick auf den KRIEG:
Webapp.war
.
|-- error.xhtml
|-- index.xhtml
|-- language.xhtml
|-- login.xhtml
|-- META-INF
|-- register.xhtml
|-- resources
| |-- css
| | `-- layout.css
| |-- images
| | `-- logo.png
| `-- javascript
| `-- detectScreenSize.js
|-- sendMail.xhtml
|-- templates
| `-- masterLayout.xhtml
`-- WEB-INF
|-- beans.xml
|-- classes
| |-- ApplicationResources_es.properties
| |-- ApplicationResources.properties
| |-- com
| | `-- webapp
| | |-- controller
| | | |-- auth
| | | | |-- ClientInfo.class
| | | | |-- LoginModule.class
| | | | |-- RBAC.class
| | | | |-- SimpleGroup.class
| | | | `-- SimplePrincipal.class
| | | |-- LocaleManager.class
| | | |-- SendMailBean.class
| | | |-- UserRegistration.class
| | | `-- UserRemoval.class
| | |-- data
| | | `-- UserListProducer.class
| | |-- exception
| | | |-- ViewExpiredExceptionExceptionHandler.class
| | | `-- ViewExpiredExceptionExceptionHandlerFactory.class
| | |-- model
| | | |-- Entity.class
| | | |-- LoginHistory.class
| | | |-- Role.class
| | | |-- User.class
| | | `-- UserRole.class
| | `-- util
| | |-- Resources.class
| | |-- TimestampAdapter.class
| | `-- Util.class
| |-- META-INF
| | |-- beans.xml
| | `-- persistence.xml
| `-- ValidationMessages.properties
|-- faces-config.xml
|-- jboss-web.xml
|-- lib
| |-- cssparser-0.9.5.jar
| |-- guava-r08.jar
| |-- richfaces-components-api-4.0.0.Final.jar
| |-- richfaces-components-ui-4.0.0.Final.jar
| |-- richfaces-core-api-4.0.0.Final.jar
| |-- richfaces-core-impl-4.0.0.Final.jar
| `-- sac-1.3.jar
|-- navigation.xml
`-- web.xml
Nun, hier ist das OHR. Dieselben Dateien (außer jetzt es hat application.xml), nur anders strukturiert.
Webapp.ear
.
|-- META-INF
| |-- application.xml
| |-- MANIFEST.MF
| `-- maven
| `-- com.webapp
| `-- Webapp-ear
| |-- pom.properties
| `-- pom.xml
|-- Webapp-ejb-1.0-SNAPSHOT.jar
`-- Webapp-web-1.0-SNAPSHOT.war
Hier ist der EJB-JAR-Datei:
Webapp-ejb-1.0-SNAPSHOT.jar
.
|-- ApplicationResources_es.properties
|-- ApplicationResources.properties
|-- com
| `-- webapp
| |-- controller
| | |-- auth
| | | |-- ClientInfo.class
| | | |-- LoginModule.class
| | | |-- RBAC.class
| | | |-- SimpleGroup.class
| | | `-- SimplePrincipal.class
| | |-- LocaleManager.class
| | |-- SendMailBean.class
| | |-- UserRegistration.class
| | `-- UserRemoval.class
| |-- data
| | `-- UserListProducer.class
| |-- exception
| | |-- ViewExpiredExceptionExceptionHandler.class
| | `-- ViewExpiredExceptionExceptionHandlerFactory.class
| |-- model
| | |-- Entity.class
| | |-- LoginHistory.class
| | |-- Role.class
| | |-- User.class
| | `-- UserRole.class
| `-- util
| |-- Resources.class
| |-- TimestampAdapter.class
| `-- Util.class
|-- META-INF
| |-- beans.xml
| |-- MANIFEST.MF
| |-- maven
| | `-- com.webapp
| | `-- Webapp-ejb
| | |-- pom.properties
| | `-- pom.xml
| `-- persistence.xml
`-- ValidationMessages.properties
Hier ist der war-Datei:
Webapp-web-1.0-SNAPSHOT.war
.
|-- error.xhtml
|-- index.xhtml
|-- language.xhtml
|-- login.xhtml
|-- META-INF
| |-- MANIFEST.MF
| `-- maven
| `-- com.webapp
| `-- Webapp-web
| |-- pom.properties
| `-- pom.xml
|-- register.xhtml
|-- resources
| |-- css
| | `-- layout.css
| |-- images
| | `-- logo.png
| `-- javascript
| `-- detectScreenSize.js
|-- sendMail.xhtml
|-- templates
| `-- masterLayout.xhtml
`-- WEB-INF
|-- beans.xml
|-- faces-config.xml
|-- jboss-web.xml
|-- lib
| |-- cssparser-0.9.5.jar
| |-- guava-r08.jar
| |-- richfaces-components-api-4.0.0.Final.jar
| |-- richfaces-components-ui-4.0.0.Final.jar
| |-- richfaces-core-api-4.0.0.Final.jar
| |-- richfaces-core-impl-4.0.0.Final.jar
| `-- sac-1.3.jar
|-- navigation.xml
`-- web.xml
Hier ist die application.xml in der Bereitstellung der EAR-Dateien:
<?xml version="1.0" encoding="UTF-8"?>
<application xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/application_6.xsd" version="6">
<display-name>Webapp-ear</display-name>
<module>
<web>
<web-uri>Webapp-web-1.0-SNAPSHOT.war</web-uri>
<context-root>/Webapp</context-root>
</web>
</module>
<module>
<ejb>Webapp-ejb-1.0-SNAPSHOT.jar</ejb>
</module>
<library-directory>lib</library-directory>
</application>
Dem KRIEG setzt, ohne Fehler, aber das OHR nicht bereitgestellt wie folgt:
17:41:02,059 WARN [org.jboss.modules] (MSC service thread 1-2) Failed to define class com.webapp.exception.ViewExpiredExceptionExceptionHandler in Module "deployment.Webapp.ear.Webapp-ejb-1.0-SNAPSHOT.jar:main" from Service Module Loader: java.lang.LinkageError: Failed to link com/webapp/exception/ViewExpiredExceptionExceptionHandler (Module "deployment.Webapp.ear.Webapp-ejb-1.0-SNAPSHOT.jar:main" from Service Module Loader)
at org.jboss.modules.ModuleClassLoader.defineClass(ModuleClassLoader.java:396)
at org.jboss.modules.ModuleClassLoader.loadClassLocal(ModuleClassLoader.java:243)
at org.jboss.modules.ModuleClassLoader$1.loadClassLocal(ModuleClassLoader.java:73)
at org.jboss.modules.Module.loadModuleClass(Module.java:505)
at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:182)
at org.jboss.modules.ConcurrentClassLoader.performLoadClassUnchecked(ConcurrentClassLoader.java:468)
at org.jboss.modules.ConcurrentClassLoader.performLoadClassChecked(ConcurrentClassLoader.java:456)
at org.jboss.modules.ConcurrentClassLoader.performLoadClass(ConcurrentClassLoader.java:398)
at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:120)
at org.jboss.as.jpa.hibernate4.HibernateAnnotationScanner.getPackagesInJar(HibernateAnnotationScanner.java:92)
at org.hibernate.ejb.Ejb3Configuration.addScannedEntries(Ejb3Configuration.java:490) [hibernate-entitymanager-4.0.0.Final.jar:4.0.0.Final]
at org.hibernate.ejb.Ejb3Configuration.scanForClasses(Ejb3Configuration.java:852) [hibernate-entitymanager-4.0.0.Final.jar:4.0.0.Final]
at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:597) [hibernate-entitymanager-4.0.0.Final.jar:4.0.0.Final]
at org.hibernate.ejb.HibernatePersistence.createContainerEntityManagerFactory(HibernatePersistence.java:72) [hibernate-entitymanager-4.0.0.Final.jar:4.0.0.Final]
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl.createContainerEntityManagerFactory(PersistenceUnitServiceImpl.java:149) [jboss-as-jpa-7.1.0.CR1b.jar:7.1.0.CR1b]
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl.start(PersistenceUnitServiceImpl.java:79) [jboss-as-jpa-7.1.0.CR1b.jar:7.1.0.CR1b]
at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1824)
at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1759)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) [:1.7.0_02]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) [:1.7.0_02]
at java.lang.Thread.run(Thread.java:722) [:1.7.0_02]
Caused by: java.lang.NoClassDefFoundError: javax/faces/context/ExceptionHandlerWrapper
at java.lang.ClassLoader.defineClass1(Native Method) [:1.7.0_02]
at java.lang.ClassLoader.defineClass(ClassLoader.java:791) [:1.7.0_02]
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) [:1.7.0_02]
at org.jboss.modules.ModuleClassLoader.doDefineOrLoadClass(ModuleClassLoader.java:327)
at org.jboss.modules.ModuleClassLoader.defineClass(ModuleClassLoader.java:391)
... 20 more
Caused by: java.lang.ClassNotFoundException: javax.faces.context.ExceptionHandlerWrapper from [Module "deployment.Webapp.ear.Webapp-ejb-1.0-SNAPSHOT.jar:main" from Service Module Loader]
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.performLoadClass(ConcurrentClassLoader.java:398)
at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:120)
... 25 more
17:41:02,143 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-2) MSC00001: Failed to start service jboss.persistenceunit."Webapp.ear/Webapp-ejb-1.0-SNAPSHOT.jar#PostgresPersistenceUnit": org.jboss.msc.service.StartException in service jboss.persistenceunit."Webapp.ear/Webapp-ejb-1.0-SNAPSHOT.jar#PostgresPersistenceUnit": Failed to start service
at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1780) [jboss-msc-1.0.1.GA.jar:1.0.1.GA]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) [:1.7.0_02]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) [:1.7.0_02]
at java.lang.Thread.run(Thread.java:722) [:1.7.0_02]
Caused by: java.lang.RuntimeException: error trying to scan <jar-file>: vfs:/content/Webapp.ear/Webapp-ejb-1.0-SNAPSHOT.jar/
at org.hibernate.ejb.Ejb3Configuration.scanForClasses(Ejb3Configuration.java:855)
at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:597)
at org.hibernate.ejb.HibernatePersistence.createContainerEntityManagerFactory(HibernatePersistence.java:72)
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl.createContainerEntityManagerFactory(PersistenceUnitServiceImpl.java:149)
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl.start(PersistenceUnitServiceImpl.java:79)
at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1824) [jboss-msc-1.0.1.GA.jar:1.0.1.GA]
at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1759) [jboss-msc-1.0.1.GA.jar:1.0.1.GA]
... 3 more
Caused by: java.lang.RuntimeException: JBAS011431: Could not load entity class 'com.webapp.exception.ViewExpiredExceptionExceptionHandler' with PersistenceUnitInfo.getNewTempClassLoader()
at org.jboss.as.jpa.hibernate4.HibernateAnnotationScanner.getPackagesInJar(HibernateAnnotationScanner.java:96)
at org.hibernate.ejb.Ejb3Configuration.addScannedEntries(Ejb3Configuration.java:490)
at org.hibernate.ejb.Ejb3Configuration.scanForClasses(Ejb3Configuration.java:852)
... 9 more
Caused by: java.lang.ClassNotFoundException: com.webapp.exception.ViewExpiredExceptionExceptionHandler from [Module "deployment.Webapp.ear.Webapp-ejb-1.0-SNAPSHOT.jar:main" from Service Module Loader]
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.performLoadClass(ConcurrentClassLoader.java:398)
at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:120)
at org.jboss.as.jpa.hibernate4.HibernateAnnotationScanner.getPackagesInJar(HibernateAnnotationScanner.java:92)
... 11 more
Es ist merkwürdig, dass der Fehler ist:
Caused by: java.lang.RuntimeException: JBAS011431: Could not load entity class 'com.webapp.exception.ViewExpiredExceptionExceptionHandler' with PersistenceUnitInfo.getNewTempClassLoader()
Den ViewExpiredExceptionHandler
ist eine Entität, also warum sollte PersistenceUnitInfo
versuchen, es zu laden?
Benutzte ich die "org.jboss.spec.archetypes:jboss-javaee6-ear-webapp"
maven archetype zu generieren, die Vorlage und poms für das EAR-Projekt, und ich benutze maven jboss-as:deploy
plugin zum bereitstellen der EAR. Ich bin mit jboss-as-7.1.0.CR1b
.
Meine web.xml ist servlet spec 3.0:
<web-app
version="3.0"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
Was bin ich nicht immer hier? Bitte helfen Sie.
InformationsquelleAutor Patrick Garner | 2012-02-05
Du musst angemeldet sein, um einen Kommentar abzugeben.
Zunächst Ihre EJB-beans sollte niemals davon abhängen, JSF-Bibliotheken. JSF ist-framework für view-Teil der Anwendung (html+backing beans). EJB-Modul sollte funktionieren ohne das wissen über JSF.
Wenn Sie wirklich brauchen, um Referenz von JSF EJB-Methode Sie haben ausdrücklich informieren container (JBoss 7.1.) das Modul richtet sich auf den JSF-Modul. Details finden Sie hier:
https://docs.jboss.org/author/display/AS7/Class+Laden+in+AS7
InformationsquelleAutor pWoz
Wenn ein EAR-Bereitstellung, EJB ' s, sollte in der
/lib
Verzeichnis der OHR-oder müssen Sie<ear-subdeployments-isolated>false</ear-subdeployments-isolated>
um die EE-subsystem zu erkennen, die EJB-JAR.Andere option wäre hinzuzufügen
Dependencies: Webapp-ejb-1.0-SNAPSHOT
zu dem MANIFEST.MF in den KRIEG.Mehr Informationen erhalten Sie auf laden von Klassen, die mit OHR, die aus der folgenden Dokumentation https://docs.jboss.org/author/display/AS7/Class+Laden+in+AS7.
Aber das problem das ich habe ist unabhängig von Modulen in einer EAR-Zugriff auf andere Klassen innerhalb des OHR. Um zu Debuggen, habe ich entfernt, ViewExpiredExceptionHandler von der Anwendung und entdeckt, dass das zugrunde liegende problem ist, dass die Klassen im EJB-Modul kann nicht auf ein beliebiges Objekt in die Gesichter.Kontext.* Pakete, sonst wird eine ClassNotFoundException geworfen wird. Wenn ich entfernen Sie Verweise auf FacesContext, ActionEvent, etc. Objekte, die die Anwendung bereitstellt, ohne Fehler. Es muss einen bug mit JBoss AS7. Es gibt eine Diskussion darüber, es, hier.
Okay, bereit auf das forum, es sieht aus wie es gibt einige Abhängigkeiten, die Sie brauchen, um hinzuzufügen, um Ihre EJB-deployment. Es sieht aus wie Sie werden besser helfen, also lasse ich es zu den Foren 🙂
Ich bin auch vor dem gleichen Problem. Können Sie mir bitte sagen, wo, um <Ohr-subdeployments-isoliert>false</Ohr-subdeployments-isoliert> diese Zeile ? Eigentlich bin ich nicht immer der Begriff EE-subsystem. Also in welche Datei soll ich diese Zeile einfügen.
Bitte siehe stackoverflow.com/questions/32479487/... thread
InformationsquelleAutor James R. Perkins