【问题标题】:Unable to migrate my WAR file from Tomcat to Weblogic 12c无法将我的 WAR 文件从 Tomcat 迁移到 Weblogic 12c
【发布时间】:2017-12-12 10:09:38
【问题描述】:

我正在尝试将我的 Web 服务从 Tomcat 8.5 迁移到 Weblogic 12c。我的项目在 Tomcat 上运行良好,所以我期待它也会很好,因为它们都使用相同版本的 Java。

在我使用 Weblogic 控制台部署我的 WAR 后,它说它的状态很好并且正在运行。但是当我使用 Chrome 连接到它时,它总是给出错误 500。即使我深入研究 Weblogic 的日志也很难猜出它出了什么问题

<Error> <HTTP> <AdminServer> <[ACTIVE] ExecuteThread: '10' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <f21f82c8-a7fe-4d00-9ead-58094613f623-00000045> <1513072074680> <[severity-value: 8] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-101020> <[ServletContext@715231355[app:testCMS module:testCMS.war path:null spec-version:3.1]] Servlet failed with an Exception
java.lang.NullPointerException
    at weblogic.servlet.internal.ServletRequestImpl$CookieKey.hashCode(ServletRequestImpl.java:2084)
    at java.util.HashMap.hash(HashMap.java:338)
    at java.util.HashMap.get(HashMap.java:556)
    at weblogic.servlet.internal.ServletRequestImpl$SessionHelper.getSessionIDFromMap(ServletRequestImpl.java:2819)
    at weblogic.servlet.internal.ServletRequestImpl$SessionHelper._getSessionInternal(ServletRequestImpl.java:2902)
    at weblogic.servlet.internal.ServletRequestImpl$SessionHelper.getSessionInternal(ServletRequestImpl.java:2869)
    at weblogic.servlet.internal.ServletRequestImpl$SessionHelper.getSession(ServletRequestImpl.java:2859)
    at weblogic.servlet.internal.ServletRequestImpl.getSession(ServletRequestImpl.java:1513)
    at weblogic.servlet.internal.ServletResponseImpl.encodeURL(ServletResponseImpl.java:690)
    at weblogic.servlet.internal.ServletResponseImpl.encodeRedirectURL(ServletResponseImpl.java:673)
    at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2226)
    at weblogic.servlet.internal.ServletRequestImpl.runInternal(ServletRequestImpl.java:1691)
    at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1651)
    at weblogic.servlet.provider.ContainerSupportProviderImpl$WlsRequestExecutor.run(ContainerSupportProviderImpl.java:270)
    at weblogic.invocation.ComponentInvocationContextManager._runAs(ComponentInvocationContextManager.java:348)
    at weblogic.invocation.ComponentInvocationContextManager.runAs(ComponentInvocationContextManager.java:333)
    at weblogic.work.LivePartitionUtility.doRunWorkUnderContext(LivePartitionUtility.java:54)
    at weblogic.work.PartitionUtility.runWorkUnderContext(PartitionUtility.java:41)
    at weblogic.work.SelfTuningWorkManagerImpl.runWorkUnderContext(SelfTuningWorkManagerImpl.java:640)
    at weblogic.work.ExecuteThread.execute(ExecuteThread.java:406)
    at weblogic.work.ExecuteThread.run(ExecuteThread.java:346)

谁能告诉我如何解决这个奇怪的问题?

【问题讨论】:

  • 嗯,不知何故它自己解决了,我不知道发生了什么。我会做更多的测试,看看它是否没有问题。
  • 不,它仍然被窃听......

标签: java tomcat war weblogic12c


【解决方案1】:

好的,我自己找到了答案。

看起来 JSP 网站需要在 WEB-INF 文件夹中包含 web.xml 和 web.xml,这样您就可以在 Weblogic 上正确部署带有 JSP 的 WAR。

我不确定为什么 Weblogic 部署需要该文件,但其他文件(例如:WAS/JBOSS/etc)暂时没有时间找出原因。

如果其他 Weblogic 开发新手也遇到过像我这样的问题,如果您需要像我一样的示例,我会在此处发布 weblogic.xml 内容。

<?xml version="1.0" encoding="UTF-8"?>
<wls:weblogic-web-app xmlns:wls="http://xmlns.oracle.com/weblogic/weblogic-web-app" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd http://xmlns.oracle.com/weblogic/weblogic-web-app http://xmlns.oracle.com/weblogic/weblogic-web-app/1.9/weblogic-web-app.xsd">
    <wls:weblogic-version>12.2.1.2</wls:weblogic-version>
    <wls:context-root>testCMS</wls:context-root>
</wls:weblogic-web-app>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-05-10
    • 2010-12-29
    • 1970-01-01
    • 1970-01-01
    • 2014-02-01
    • 1970-01-01
    • 2019-03-09
    • 1970-01-01
    相关资源
    最近更新 更多