Maven 和 RAD 产生不同的 EAR
Maven and RAD produce different EARs
我必须从 RAD 9.5 和 maven 构建一个项目(Parent 和 EAR,其中包含 jar、ejb 和 2 个 war 模块)。
当我从 maven 命令行构建项目时,一切正常。它正在创建在 WebSphere 8.5.5 上运行的瘦 wars 存档。
尝试从 RAD 更新项目或导出 EAR 时,我得到的文件不同且无法工作,EJB 的依赖项之一出现 ClassNotFoundException。
进一步观察,我发现类路径部分的 MANIFEST.MF 有所不同。 Maven 项目将带有 lib/ 前缀和 m2e/RAD 的实例放在那里,就像这样:
Class-Path: lib/log4j-api-2.6.jar lib/log4j-core-2.6.jar lib/junit-4.12.jar lib/hamcrest-core-1.3.
纯 maven 和:
Class-Path: log4j-api-2.6.jar log4j-core-2.6.jar junit-4.12.jar hamcrest-core-1.3.
我尝试更新一个项目,使用 pom.xml 中的设置。这是我最接近工作的应用程序。
我当前的 ejb 插件配置:
<plugin>
<artifactId>maven-ejb-plugin</artifactId>
<version>2.5</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
</manifest>
</archive>
<ejbVersion>3.1</ejbVersion>
</configuration>
</plugin>
和异常(最低级别):
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
at java.net.URLClassLoader.findClass(URLClassLoader.java:600)
at com.ibm.ws.bootstrap.ExtClassLoader.findClass(ExtClassLoader.java:243)
at java.lang.ClassLoader.loadClassHelper(ClassLoader.java:786)
at java.lang.ClassLoader.loadClass(ClassLoader.java:764)
at com.ibm.ws.bootstrap.ExtClassLoader.loadClass(ExtClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:62)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:58)
at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:585)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
... 75 more
我想这是问题所在,但我不知道如何修复它。
更新:
尝试添加到清单部分:
<classpathPrefix>lib/</classpathPrefix>
同样的结果。
这是一个迂回的答案,但您可能会发现从 EE 项目开始更成功:WAR、EAR 等,然后使用 "Convert to Maven projects" 选项。
您可以找到信息 here and here。
一旦您了解了将映射回 RAD 中的 EE 项目结构的 Maven 结构,您也可以在另一个方向上工作。如果您对现有的项目格式感到满意,不确定还有多少工作要做。
我不确定我是否回答了你的问题,但这对于评论来说太长了,所以这里...
我注意到,如果我将 maven 生成的 manifest.mf 复制到项目中,然后使用 RAD 构建项目,它会将正确的文件带到最终的 EAR 中。这是一种解决方法。此外,根据 this:m2e-wtp 将仅在不存在时生成清单。
我必须从 RAD 9.5 和 maven 构建一个项目(Parent 和 EAR,其中包含 jar、ejb 和 2 个 war 模块)。
当我从 maven 命令行构建项目时,一切正常。它正在创建在 WebSphere 8.5.5 上运行的瘦 wars 存档。
尝试从 RAD 更新项目或导出 EAR 时,我得到的文件不同且无法工作,EJB 的依赖项之一出现 ClassNotFoundException。
进一步观察,我发现类路径部分的 MANIFEST.MF 有所不同。 Maven 项目将带有 lib/ 前缀和 m2e/RAD 的实例放在那里,就像这样:
Class-Path: lib/log4j-api-2.6.jar lib/log4j-core-2.6.jar lib/junit-4.12.jar lib/hamcrest-core-1.3.
纯 maven 和:
Class-Path: log4j-api-2.6.jar log4j-core-2.6.jar junit-4.12.jar hamcrest-core-1.3.
我尝试更新一个项目,使用 pom.xml 中的设置。这是我最接近工作的应用程序。
我当前的 ejb 插件配置:
<plugin>
<artifactId>maven-ejb-plugin</artifactId>
<version>2.5</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
</manifest>
</archive>
<ejbVersion>3.1</ejbVersion>
</configuration>
</plugin>
和异常(最低级别):
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
at java.net.URLClassLoader.findClass(URLClassLoader.java:600)
at com.ibm.ws.bootstrap.ExtClassLoader.findClass(ExtClassLoader.java:243)
at java.lang.ClassLoader.loadClassHelper(ClassLoader.java:786)
at java.lang.ClassLoader.loadClass(ClassLoader.java:764)
at com.ibm.ws.bootstrap.ExtClassLoader.loadClass(ExtClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:62)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:58)
at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:585)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
... 75 more
我想这是问题所在,但我不知道如何修复它。
更新: 尝试添加到清单部分:
<classpathPrefix>lib/</classpathPrefix>
同样的结果。
这是一个迂回的答案,但您可能会发现从 EE 项目开始更成功:WAR、EAR 等,然后使用 "Convert to Maven projects" 选项。
您可以找到信息 here and here。
一旦您了解了将映射回 RAD 中的 EE 项目结构的 Maven 结构,您也可以在另一个方向上工作。如果您对现有的项目格式感到满意,不确定还有多少工作要做。
我不确定我是否回答了你的问题,但这对于评论来说太长了,所以这里...
我注意到,如果我将 maven 生成的 manifest.mf 复制到项目中,然后使用 RAD 构建项目,它会将正确的文件带到最终的 EAR 中。这是一种解决方法。此外,根据 this:m2e-wtp 将仅在不存在时生成清单。