Ошибка запуска сервера WAS 8.5

Я получаю следующую ошибку при попытке развернуть EAR на WAS 8.5 в MyEclipseBlue. Кто-нибудь может помочь? Я попытался изменить порядок загрузчика классов с последнего на первый, установив metadata-complete="true" в web.xml , создав новый профиль и переустановив WAS . Кажется, ничего не работает. Пожалуйста, найдите журналы консоли ниже.

[9/17/16 16:03:06:548 IST] 00000001 ContainerHelp E   WSVR0501E: Error creating component com.ibm.ws.runtime.component.CompositionUnitMgrImpl@acf57ca5
com.ibm.ws.exception.RuntimeWarning: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: Failed to load webapp: loading constraint violation: loader &quot&#59;com/ibm/ws/classloader/CompoundClassLoader@a74d2eab&quot&#59; previously initiated loading for a different type with name &quot&#59;javax/servlet/ServletContext&quot&#59; defined by loader &quot&#59;org/eclipse/osgi/internal/baseadaptor/DefaultClassLoader@d19a0410&quot&#59;
    at com.ibm.ws.webcontainer.component.WebContainerImpl.install(WebContainerImpl.java:432)
    at com.ibm.ws.webcontainer.component.WebContainerImpl.start(WebContainerImpl.java:718)
    at com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:1170)
    at com.ibm.ws.runtime.component.DeployedApplicationImpl.fireDeployedObjectStart(DeployedApplicationImpl.java:1370)
    at com.ibm.ws.runtime.component.DeployedModuleImpl.start(DeployedModuleImpl.java:638)
    at com.ibm.ws.runtime.component.DeployedApplicationImpl.start(DeployedApplicationImpl.java:968)
    at com.ibm.ws.runtime.component.ApplicationMgrImpl.startApplication(ApplicationMgrImpl.java:769)
    at com.ibm.ws.runtime.component.ApplicationMgrImpl.start(ApplicationMgrImpl.java:2172)
    at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:445)
    at com.ibm.ws.runtime.component.CompositionUnitImpl.start(CompositionUnitImpl.java:123)
    at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.start(CompositionUnitMgrImpl.java:388)
    at com.ibm.ws.runtime.component.CompositionUnitMgrImpl.access$500(CompositionUnitMgrImpl.java:116)
    at com.ibm.ws.runtime.component.CompositionUnitMgrImpl$CUInitializer.run(CompositionUnitMgrImpl.java:994)
    at com.ibm.wsspi.runtime.component.WsComponentImpl$_AsynchInitializer.run(WsComponentImpl.java:349)
    at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1783)
Caused by: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: Failed to load webapp: loading constraint violation: loader &quot&#59;com/ibm/ws/classloader/CompoundClassLoader@a74d2eab&quot&#59; previously initiated loading for a different type with name &quot&#59;javax/servlet/ServletContext&quot&#59; defined by loader &quot&#59;org/eclipse/osgi/internal/baseadaptor/DefaultClassLoader@d19a0410&quot&#59;
    at com.ibm.ws.webcontainer.WSWebContainer.addWebApp(WSWebContainer.java:759)
    at com.ibm.ws.webcontainer.WSWebContainer.addWebApplication(WSWebContainer.java:634)
    at com.ibm.ws.webcontainer.component.WebContainerImpl.install(WebContainerImpl.java:426)
    ... 14 more
Caused by: com.ibm.ws.webcontainer.exception.WebAppNotLoadedException: Failed to load webapp: loading constraint violation: loader "com/ibm/ws/classloader/CompoundClassLoader@a74d2eab" previously initiated loading for a different type with name "javax/servlet/ServletContext" defined by loader "org/eclipse/osgi/internal/baseadaptor/DefaultClassLoader@d19a0410"
    at com.ibm.ws.webcontainer.VirtualHostImpl.addWebApplication(VirtualHostImpl.java:176)
    at com.ibm.ws.webcontainer.WSWebContainer.addWebApp(WSWebContainer.java:749)
    ... 16 more
Caused by: java.lang.LinkageError: loading constraint violation: loader "com/ibm/ws/classloader/CompoundClassLoader@a74d2eab" previously initiated loading for a different type with name "javax/servlet/ServletContext" defined by loader "org/eclipse/osgi/internal/baseadaptor/DefaultClassLoader@d19a0410"
    at java.lang.ClassLoader.defineClassImpl(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:262)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:69)
    at com.ibm.ws.classloader.CompoundClassLoader._defineClass(CompoundClassLoader.java:852)
    at com.ibm.ws.classloader.CompoundClassLoader.localFindClass(CompoundClassLoader.java:762)
    at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:603)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:627)
    at com.sun.xml.ws.transport.http.servlet.WSServletContainerInitializer.onStartup(WSServletContainerInitializer.java:61)
    at com.ibm.ws.webcontainer.webapp.WebAppImpl.initializeServletContainerInitializers(WebAppImpl.java:613)
    at com.ibm.ws.webcontainer.webapp.WebAppImpl.initialize(WebAppImpl.java:409)
    at com.ibm.ws.webcontainer.webapp.WebGroupImpl.addWebApplication(WebGroupImpl.java:88)
    at com.ibm.ws.webcontainer.VirtualHostImpl.addWebApplication(VirtualHostImpl.java:169)
    ... 17 more

person Twisha    schedule 17.09.2016    source источник
comment
Предположительно, вы упаковали API сервлета в свое приложение, поэтому вам следует удалить его. FWIW, в принципе невозможно получить LinkageError, как это, если только ваше приложение или загрузчик класса модуля не установлен в родительский последний. Если вы изменили родительский элемент последним на родительский первый и по-прежнему видите какую-то ошибку, я подозреваю, что это не то же самое, что ошибка, которую вы здесь указали.   -  person Brett Kail    schedule 17.09.2016
comment
Спасибо @Brett, удалив банку servlet-api, решил проблему, но я все еще получаю сообщение об ошибке, например Вызвано: java.lang.NoClassDefFoundError: org.slf4j.LoggerFactory (ошибка инициализации) во время запуска сервера. Сервер работает, а приложение нет.   -  person Twisha    schedule 19.09.2016
comment
Всю трассировку стека можно найти здесь: stackoverflow.com/questions/39571158/   -  person Twisha    schedule 19.09.2016
comment
Вторая проблема была решена после того, как я добавил еще одну банку в путь к классам slf4j-simple-1.7.5.jar.   -  person Twisha    schedule 19.09.2016
comment
Я рад, что у тебя все получилось. Я добавил ответ, если вы хотите его принять, нажав на галочку слева от него.   -  person Brett Kail    schedule 19.09.2016


Ответы (1)


Предположительно, вы упаковали API сервлета в свое приложение, поэтому вам следует удалить его. FWIW, в принципе невозможно получить LinkageError, как это, если только ваше приложение или загрузчик класса модуля не установлен на «последний родитель». Если вы изменили родительский элемент последним на родительский первый и по-прежнему видите какую-то ошибку, я подозреваю, что это не то же самое, что ошибка, которую вы здесь указали.

person Brett Kail    schedule 19.09.2016