Ошибка развертывания приложения на JBoss 5, которое нормально работало на JBoss 4.2 - PullRequest
7 голосов
/ 10 февраля 2009

Я пытаюсь развернуть приложение (файл .ear) в JBoss 5, и я получаю следующую ошибку. Приложение прекрасно развертывается под 4.2.2.

15:31:33,172 ERROR [AbstractKernelController] Error installing to Real: name=vfszip:/C:/ASE/ext/jboss-5.0.0.GA/server/all/dep
loy/UGC-WS.ear state=PreReal mode=Manual requiredState=Real
org.jboss.deployers.spi.DeploymentException: Error during deploy: vfszip:/C:/ASE/ext/jboss-5.0.0.GA/server/all/deploy/UGC-WS.
ear/ugc-ws.war
at org.jboss.deployers.spi.DeploymentException.rethrowAsDeploymentException(DeploymentException.java:49)
at org.jboss.deployers.plugins.deployers.DeployerWrapper.deploy(DeployerWrapper.java:177)
at org.jboss.deployers.plugins.deployers.DeployersImpl.doDeploy(DeployersImpl.java:1439)
at org.jboss.deployers.plugins.deployers.DeployersImpl.doInstallParentFirst(DeployersImpl.java:1157)
at org.jboss.deployers.plugins.deployers.DeployersImpl.doInstallParentFirst(DeployersImpl.java:1210)
at org.jboss.deployers.plugins.deployers.DeployersImpl.install(DeployersImpl.java:1098)
at org.jboss.dependency.plugins.AbstractControllerContext.install(AbstractControllerContext.java:348)
at org.jboss.dependency.plugins.AbstractController.install(AbstractController.java:1598)
at org.jboss.dependency.plugins.AbstractController.incrementState(AbstractController.java:934)
at org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:1062)
at org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:984)
at org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:822)
at org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:553)
at org.jboss.deployers.plugins.deployers.DeployersImpl.process(DeployersImpl.java:781)
at org.jboss.deployers.plugins.main.MainDeployerImpl.process(MainDeployerImpl.java:545)
at org.jboss.system.server.profileservice.ProfileServiceBootstrap.loadProfile(ProfileServiceBootstrap.java:304)
at org.jboss.system.server.profileservice.ProfileServiceBootstrap.start(ProfileServiceBootstrap.java:205)
at org.jboss.bootstrap.AbstractServerImpl.start(AbstractServerImpl.java:405)
at org.jboss.Main.boot(Main.java:209)
at org.jboss.Main$1.run(Main.java:547)
at java.lang.Thread.run(Thread.java:595)
Caused by: java.lang.ClassCastException: org.jboss.metadata.ear.spec.JavaModuleMetaData
at org.jboss.wsf.container.jboss50.deployment.metadata.JSEArchiveMetaDataAdapter.buildMetaData(JSEArchiveMetaDataAdap
ter.java:76)
at org.jboss.wsf.container.jboss50.deployment.metadata.ContainerMetaDataAdapter.buildContainerMetaData(ContainerMetaD
ataAdapter.java:76)
at org.jboss.wsf.container.jboss50.deployment.metadata.ContainerMetaDataDeploymentAspect.create(ContainerMetaDataDepl
oymentAspect.java:51)
at org.jboss.wsf.framework.deployment.DeploymentAspectManagerImpl.create(DeploymentAspectManagerImpl.java:121)
at org.jboss.wsf.container.jboss50.BareWSFRuntime.create(BareWSFRuntime.java:61)
at org.jboss.wsf.container.jboss50.deployer.ArchiveDeployerHook.deploy(ArchiveDeployerHook.java:84)
at org.jboss.wsf.container.jboss50.deployer.AbstractDeployerHookEJB.deploy(AbstractDeployerHookEJB.java:43)
at org.jboss.wsf.container.jboss50.deployer.AbstractWebServiceDeployer.internalDeploy(AbstractWebServiceDeployer.java
:60)
at org.jboss.wsf.container.jboss50.deployer.WebServiceDeployerEJB.internalDeploy(WebServiceDeployerEJB.java:112)
at org.jboss.deployers.spi.deployer.helpers.AbstractRealDeployer.deploy(AbstractRealDeployer.java:50)
at org.jboss.deployers.plugins.deployers.DeployerWrapper.deploy(DeployerWrapper.java:171)
... 19 more
15:31:33,203 ERROR [ProfileServiceBootstrap] Failed to load profile: Summary of incomplete deployments (SEE PREVIOUS ERRORS F
OR DETAILS):

*** CONTEXTS IN ERROR: Name -> Error

vfszip:/C:/ASE/ext/jboss-5.0.0.GA/server/all/deploy/UGC-WS.ear -> java.lang.ClassCastException: org.jboss.metadata.ear.spec.J
avaModuleMetaData

Это сообщение об ошибке от консоли, и я не могу многое понять из этого ...

Приложение содержит только веб-службы и сервлет, который загружается при запуске для инициализации и кэширования некоторых данных.

У нас есть EAR-файл, который содержит несколько JAR-файлов (один из них называется ugc-ws.jar) для библиотек, которые мы используем, а также файл WAR, в котором есть файл web.xml для загрузки сервлета - это WAR У файла также есть тот же ugc-ws.jar в каталоге lib, потому что сервлет находится внутри этого JAR-файла. Таким образом, в основном у нас есть основной файл EAR и несколько файлов JAR, а также файл WAR, который также содержит файл JAR внутри своего каталога lib. И ошибка выглядит так, как будто она из WAR.

Это вывод "jar -tf ugc-ws.war":

>jar -tf ugc-ws.war
META-INF/
META-INF/MANIFEST.MF
WEB-INF/
WEB-INF/web.xml
WEB-INF/lib/
WEB-INF/jboss-web.xml
WEB-INF/lib/ugc-ws.jar

Просто для тестирования я удалил файл .WAR из .EAR, и приложение развернулось без ошибок, но, очевидно, без данных из WAR, я не могу использовать приложение. Способ развертывания - просто перетащить файл .EAR в каталог server \ all \ deploy.

Я попытался разделить файл ugc-ws.jar на два отдельных jar-файла, один только с веб-сервисами, а другой без сервлета, но я все еще получаю ту же ошибку.

Просто странно, что это хорошо работало в JBoss 4, но не в JBoss 5.

Спасибо

1 Ответ

8 голосов
/ 11 февраля 2009

Это не странно.

JBoss 4.2 НЕ совместим с Java5EE. Соответствует JBoss 5.0.

Мне кажется, что у вас есть проблемные условия где-то на вашей войне. Ошибка появляется только в JBoss 5, так как в этой версии применяется корректность.

Просто быстрое предположение. Ваш jboss-web.xml может иметь неправильный dtd. Проверьте это .

Я также советую перечитать документацию JBoss и особенно заметки о выпуске. для 5.0 и любые советы по миграции, которые они имеют для пользователей 4.2

...