7.20. 模块类加载更改
在 JBoss EAP 7 中,当多个模块包含多个类或软件包时,类加载行为已更改。
假设有两个模块 MODULE_A 和 MODULE_B,它们相互依赖,并包含其中一些相同的软件包。在 JBoss EAP 6 中,从依赖项加载的类或软件包优先于 module.xml 文件的 resource-root 中指定的类或软件包。这意味着 MODULE_A 看到 MODULE_B 和 MODULE_B 的软件包会看到 MODULE_A 的软件包。这个行为令人混淆,可能会导致冲突。JBoss EAP 7 中已更改此行为。现在,module.xml 文件中的 resource-root 指定的类或软件包优先于由依赖项指定的那些。这意味着 MODULE_A 查看 MODULE_A 和 MODULE_B 的软件包是 MODULE_B 的软件包。这可防止冲突,并提供更适当的行为。
如果您定义了自定义模块,其中包含 resource-root 库或包含在其模块依赖项中重复的类的软件包,您可能会看到 ClassCastException、LinkageError、类加载错误或其他在迁移到 JBoss EAP 7 时的行为更改。要解决这个问题,您必须配置 module.xml 文件,以确保只使用一个类版本。这可以通过以下方法之一来实现。
-
您可以避免指定在模块依赖项中重复类的
resource-root。 您可以使用
importsandexports元素的include和exclude子元素来控制module.xml文件中的类加载。以下是排除类在指定软件包中的导出元素。<exports> <exclude path="com/mycompany/duplicateclassespath/"/> </exports>
如果要保留现有行为,则必须使用 filter 元素过滤 module.xml 文件中的依赖 resource-root 的依赖项软件包。这样,您可以保留现有的行为,而无需在 JBoss EAP 6 下看到的奇数循环。以下是一个 root-resource 示例,它可过滤指定软件包中的类。
<resource-root path="mycompany.jar">
<filter>
<exclude path="com/mycompany/duplicateclassespath"/>
</filter>
</resource-root>
有关模块和类加载的更多信息,请参阅 JBoss EAP 7.4 开发指南中的 类加载和模块。