登录
首页 >  文章 >  java教程

解决Spring Boot部署到WebLogic中的Jar包冲突问题

来源:亿速云

时间:2024-03-28 09:30:26 487浏览 收藏

最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《解决Spring Boot部署到WebLogic中的Jar包冲突问题》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

背景

某项目,客户要求使用已有的 weblogic 部署已经开发好的 springboot,于是乎对 springboot 进行了部分配置的调整,主要包括去除 tomcat 依赖,增加启动类的处理。

一般都会比较顺利,实际上总会遇到些小问题。

问题1

打包后发布到 weblogic 上启动时,如下图所示的错误:

springboot部署到weblogic中jar包冲突如何解决

从异常内容可以很容易判断出,这是 jar 包冲突导致的错误。

经过定位,weblogic 有个目录 wls12213\oracle_common\modules\thirdparty,其中存放了一些第三方的默认的 jar 包,项目启动过程中默认是先加载这里的 jar 包,再加载项目工程中的 jar 包,因为你无法保证项目工程中的 jar 包和 weblogic 中的 jar 包版本刚好一致,所以就因为 jar 包版本不一致出现了比较常见的类加载冲突的问题。

查阅官网资料,weblogic 也有是解决方案的,可以通过新增并配置 weblogic.xml 文件来定义哪些类需要优先从项目工程包的 jar 包中加载。

配置方法如下:

在 springboot 项目代码和 resource 同级创建一个 webapp 目录,然后再 webapp 目录下创建 WEB-INF 目录,将 weblogic.xml 文件放在 WEB-INF 中,以 springboot-weblogic-demo 工程为例它的完整路径就是 springboot-weblogic-demo\\src\main\webapp\WEB-INF\weblogic.xml,其内容如下:



    
        
            org.slf4j
            javax.validation.*
            org.hibernate.*
            javax.el.*
            org.springframework.*
            
            com.fasterxml.jackson.*
        
    
    /springboot-weblogic-demo

仅仅是添加配置了这一个文件,没有其他什么配置了,网上说的那些添加 web.xml 的操作,我这里并没有添加,示例是基于 springboot 2.7.2 正常部署运行。

问题2

部署的过程中还出现了 GC 错误 GC overhead limit exceeded,这个问题比较容易解决,给 weblogic 启动环境修改内存值,调大一些即可。

修改对应文件 D:\weblogic\fmw_12.2.1.3.0_wls_quick_Disk1_1of1\wls12213\user_projects\domains\base_domain\bin\setDomainEnv.cmd,大约在 200 行出头的位置,修改后的内容如下:

if NOT "%JAVA_VENDOR%"=="HP" (
	if "%VM_TYPE%"=="HotSpot" (
		set WLS_MEM_ARGS_64BIT=-Xms1024m -Xmx4096m
		set WLS_MEM_ARGS_32BIT=-Xms256m -Xmx512m
	)
)

重启 weblogic 服务,最开始就能看到我们修改后剩下的内存配置:

springboot部署到weblogic中jar包冲突如何解决

WLS_MEM_ARGS_64BIT 的原始值为 -Xms256m -Xmx512m,或者你也可以追加更多关于内存的设置,例如:-Xms512m -Xmx1024m -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m

以上就是《解决Spring Boot部署到WebLogic中的Jar包冲突问题》的详细内容,更多关于SpringBoot,weblogic,jar的资料请关注golang学习网公众号!

声明:本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>