zoukankan      html  css  js  c++  java
  • 记一次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服务后,居然神奇的可以访问到项目了,这是什么骚操作。 一脸懵逼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,再部署应用,到此结束! 

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

  • 相关阅读:
    word 导出(带有一个图片,一张datatable)
    asp.net 获取当前时间的格式
    解决<compilation debug="true" targetFramework="4.0"> 问题
    安装office专业增强版2016(word/excel/ppt/visio)的记录
    JS,Jquery获取各种屏幕的宽度和高度
    utc本地时间
    extjs使用gridPanel演示基于asp.net使用json传送数据
    获取物料指定日期的库存
    resize
    关于完工入库研究
  • 原文地址:https://www.cnblogs.com/cooldamon/p/10515099.html
Copyright © 2011-2022 走看看