记一次Weblogic发布Springboot遇到的坑

项目使用的是Springboot,之前直接使用JAR包的方式发布,但在客户这边实施发布的时候,客户使用的容器是weblogic,版本为 10.3.6。  痛苦就此开始!

不过项目组还有另外一个也同样使用了Springboot,他们已经顺利发布了,嗯~ 再百度一下, 哈哈哈,这还不是简简单单!

这个事情,随手扔给下面的技术人员搞定就ok的嘛~   结果一周过去了,跟我说项目启不来。没任何反应 。   我???

这么简单的事情都搞不定,我要你们何用?  于是我就大发慈悲,来帮帮你们吧~   我仿佛看到了 轻轻松松搞定后,他们对我投来的崇拜目光~

先把之前看到的那片文章找出来,认真研究一下。  这里感谢【书上有云】的这篇文章【https://blog.csdn.net/qq_32734365/article/details/79295535】,帮助很大!

简单说梳理一下思路,需要做如下事情:

1、将项目web调整为 servlet 2.5 ,并在pom.xml添加对应的支持依赖;

2、排除了自身的Tomcat,如果需要本地测试,则添加到provide中;

3、新增web.xml, contextConfigLocation 配置启动类,新增weblogic.xml;

4、启动类需要继承SpringBootServletInitializer、实现WebApplicationInitializer接口,重写configure方法;

5、在pom.xml中,将打包方式从jar改成war。

一切就绪,war成功编译,然而发布到weblogic,还是启动失败!  what?   肿么不对呢?

只有一个醒目的错误:Caused By: java.lang.NoClassDefFoundError: javax/servlet/MultipartConfigElement

回想可以先在本地用Tomcat6 试试,于是就先开始用Tomcat6本地调试一下。

继续把war包扔到Tomcat的webapp下面,启动ing。。。。似乎没有反应,查看log

严重: Exception sending context initialized event to listener instance of class org.springframework.boot.legacy.context.web.SpringBootContextLoaderListener
java.lang.NoClassDefFoundError: javax/servlet/MultipartConfigElement

棒棒哒! 最起码问题复现了,其实这个问题好解决,Springboot默认版本是3.0,在pom.xml中添加 servlet的包,变成2.5 就行了。  ok! 问题1消灭!!!

重新打包,Tomcat完美运行,美滋滋~

再次扔到weblogic上面,又出来一个新的玩意:

Caused By:java.lang.ClassNotFoundException: org.osjava.sj.SimpleContextFactory

这是什么鬼? 似乎没见过呀,百度一下,似乎就一个人提到这个问题,回答的也是敷衍没实质作用。

嗯,还出了一个问题,weblogic控制台没法进了。登录就弹出这个提示:

已禁用所需的MBean服务器,这将阻止WebLogic管理控制台的正常操作,

请在该域的配置中启用 DomainRuntimeMBean 服务器和 Edit MBean 服务器。

记一次Weblogic发布Springboot遇到的坑

氮素,我重启Weblogic服务后,居然神奇的可以访问到项目了,这是什么骚操作。 一脸懵逼zzz?

可是这个问题不正常呀,清理到应用,重启WebLogic,控制台又能顺利进去了,再发布应用,却怎么也启不来。就开始不停地:

Caused By:java.lang.ClassNotFoundException: org.osjava.sj.SimpleContextFactory

于是就只能回归项目代码了,应该是代码里面写了什么或者用了什么神奇的东西。

找到了这个类,原来是 simple-jndi jar包, 项目里面用kettle来实现数据同步,方便调整数据库,便用到了这个jar包,采用jndi方式配置数据源。

新的曙光已经出现,怎么能够停滞不前!  这个问题来来回回折腾好几天了,是时候把它解决了!

又研究半天代码,发现网上在写kettle使用jndi方式里面,用的System的属性定义, 感觉就是这个鬼了。

System.setProperty("java.naming.factory.initial", "org.osjava.sj.SimpleContextFactory");

然后又去找了一下Java调用 WebLogic的JNDI,不同的容器使用的Context.INITIAL_CONTEXT_FACTORY是不一样的,Weblogic需要用到如下:

System.setProperty("java.naming.factory.initial",   "weblogic.jndi.WLInitialContextFactory");

这样,一切都明朗了!  我只需要配置weblogic的jndi,并且把simple-jndi的替换掉就OK了。

调整完毕,配置好JNDI,再部署应用,到此结束!

其实,只要认真仔细分析,问题都有解决的办法!  有相同或类似问题,欢迎留言探讨~

上一篇:菜鸟浅谈“诈骗”希望“治未病"


下一篇:kettle 数据库连接中断重置