was设置共享库解决jar冲突

一、jar包冲突问题解决

1、问题描述:

引入新外围项目的jar后,在本地tomcat运行正常,但是在was服务器调用httpclient.jar中方法提示异常(该异常为系统异常,Java代码的try catch 无法捕获,was的sysout.log中才可以查看)。

2、问题原因:

项目中的commons-httpclient.jar与httpclient.jar系类的http包存在冲突(网上有的说法是项目中的jar和was自带的存在冲突,个人不认可该种说法),Tomcat的加载class顺序与was不同,所以未出问题。
was设置共享库解决jar冲突_第1张图片

3、解决方案:

通过建立共享库,改变was加载顺序,优先加载httpclient.jar系类jar包。共享库建立步骤如下。
(1)将需要共享的jar放到服务器有访问权限的文件夹下。
was设置共享库解决jar冲突_第2张图片
(2)打开was控制台,“环境”—“共享库”—“新建”,新建一个共享库,名称任意,类路径为上一步jar在服务器的存放路径,按如图操作后保存设置。
was设置共享库解决jar冲突_第3张图片
(3)先删除原server级别下的配置。(上个版本配置共享库时添加,该块内容可要可不要,建议删除。)
was设置共享库解决jar冲突_第4张图片
(4)打开“应用程序“—”应用程序类型“—”webSphere企业应用程序“,先停止STM项目服务,再点击STM项目进入,点击”引用共享库“,并且将本应用的类加载顺序,也改为本地优先。
was设置共享库解决jar冲突_第5张图片
was设置共享库解决jar冲突_第6张图片
was设置共享库解决jar冲突_第7张图片

二、was服务类加载顺序

1、未引用共享库时

was设置共享库解决jar冲突_第8张图片

2、Web程序引用共享库时

was设置共享库解决jar冲突_第9张图片

3、模块引用共享库时

was设置共享库解决jar冲突_第10张图片

参考:

1、websphere7.0 创建共享库,引用共享库
2、websphere7.0 jar包冲突解决办法,类加载顺序

未解决疑问:

通过打印调用http类的加载链,发现在Tomcat和was是一致的,这样就无法用以上内容解释,但是通过共享库又解决了问题,不解。

你可能感兴趣的:(中间件)