WebSphere Application Server(WAS)8.5.5教程第五讲
续前篇!
一、Web 应用部署与类加载策略
Web 应用部署与类加载策略是 WebSphere Application Server(WAS)日常管理的核心部分,尤其对运行大型企业级 Java 应用(如 BAW)非常关键。本讲将分两部分讲解:
1、目标
1. Web 应用部署:如何安装、更新、卸载 WAR/EAR 包
2. 类加载策略:如何解决类冲突、提升加载效率
2、Web 应用部署(WAR / EAR 包)
部署入口
路径如下:
应用程序 ➝ WebSphere企业应用程序
1. 安装新应用
步骤:
-
点击【安装】
-
选择上传方式:
-
从本地上传
.war
/.ear
文件 -
或者从服务器路径安装(/opt/IBM/xyz.ear)
-
-
点击【下一步】,按提示填写信息
-
应用名称(可以修改)
-
目标服务器(选定一个 WebSphere 实例)
-
安装目录设置(一般保持默认)
-
-
重要步骤:配置 上下文根(Context Root)
-
例如:
/bawportal
,则访问地址为http://host:port/bawportal
-
-
点击【完成】,然后【保存主配置】
-
启动应用程序(在“企业应用程序”列表中选中 ➝ 启动)
2. 更新已有应用
路径:
WebSphere企业应用程序 ➝ 点击应用名 ➝ 点击“更新”
选项:
-
更新整个 EAR 包(替换旧包)
-
更新单个模块(如只替换
*.war
) -
更新类、资源文件等(增量更新)
3. 卸载应用
路径:
WebSphere企业应用程序 ➝ 勾选目标 ➝ 点击【卸载】
注意事项:
-
安装后不要忘记点击右上角的【保存到主配置】
-
每次安装/更新后建议重启对应服务器,清理缓存
-
部署 BAW 类 Portal 或 Process App 时,路径/依赖较多,注意 WAR 中
web.xml
和 ClassPath 定义
3、类加载策略
在 WebSphere 中,不同组件之间共享类路径,有时会导致类冲突(比如 Jackson、Log4j 不同版本),所以类加载策略管理非常重要。
类加载相关配置位置:
-
服务器级别设置:
服务器 ➝ 点击目标服务器 ➝ 应用程序设置 ➝ 类装入器策略 -
应用程序级别设置:
企业应用程序 ➝ 点击应用名称 ➝ 类装入器
或
➝ 模块级别设置(Web 模块 / EJB 模块)
两种主要策略:
设置位置:
-
下拉选择:
类装入方式(Class loader mode)
➤ 选择Parent last
可优先加载应用自己的类
使用场景举例:
Parent last
,防止依赖冲突Parent first
(默认即可)ClassNotFoundException
/ NoSuchMethodError
4、补充:共享库(Shared Libraries)
如果多个应用使用相同的 jar 包(如 log4j.jar、common-utils.jar),建议配置为共享库,避免冗余加载。
创建方式:
-
环境 ➝ 共享库
-
新建共享库 ➝ 指定 jar 包目录
-
在应用级别(企业应用程序 ➝ 应用 ➝ 共享库映射)挂载该库
5、实战调优建议
Parent last
、使用 Shared Library6、总结
二、案例: BAW在WAS中的类加载策略与依赖管理机制
下面来深入梳理 IBM Business Automation Workflow(BAW) 在 WebSphere Application Server (WAS) 中的 类加载策略与依赖管理机制,这有助于你深入理解 BAW 各组件运行背后的逻辑,进而定位问题、调优或安全管控。
1、BAW 在 WAS 中的部署结构概览
BAW 其实是由多个模块打包成一个或多个 企业应用(EAR) 部署到 WAS 中的,核心包括:
BAW Process Server EAR
BAW Process Portal WAR
BAW Process Designer
BAW Business Rules
Common Services
2、类加载策略在 BAW 中的实际应用
IBM 官方默认使用策略:
Parent First
Parent Last
Parent Last
可在 WAS 控制台:
-
应用程序 ➝ 企业应用程序 ➝ 点击模块 ➝ 类装入器 ➝ 设置类加载方式
示例:防止 Jackson 冲突
BAW 内置 Jackson(如 com.fasterxml.jackson.core
),但你部署的自定义服务也用了别的版本?
解决方案:
-
你的自定义模块设置为
Parent Last
-
或用 Shared Library 管理 Jackson,并为各应用指定绑定版本
3、依赖管理方式
1. 内部依赖(BAW Runtime 组件)
常见 JAR 包(这些位于安装目录,例如 /opt/IBM/Workflow/lib
):
bpmserver.jar
teamworks.jar
businessrules.jar
restconnector.jar
ucaservice.jar
这些 jar 不可擅自替换,否则会导致版本冲突或运行异常。
2. 外部依赖(自定义服务所用)
如:
-
spring-core.jar
-
mybatis.jar
-
jackson-databind.jar
通常放置在:
-
WAR 模块中的
/WEB-INF/lib
-
EAR 的
lib
或APP-INF/lib
-
Shared Library 中统一管理
4、类加载调试技巧
开启类加载跟踪日志:
在 JVM 参数中添加:
-Dibm.cl.verbose=true
可以在 WAS SystemOut.log
中看到加载类的来源,例如:
[2/20/25 13:22:11:123 CST] 00000001 SystemOut O CL Verbose: Loaded class [com.fasterxml.jackson.databind.ObjectMapper] from [file:/opt/IBM/Workflow/lib/jackson-databind.jar]
常见冲突问题排查
ClassCastException
ClassNotFoundException
最佳实践总结
Parent Last
,放置独立 jar未完,待续!