2011-11-14 212 views
1

我想部署一个war文件到tomcat 6.0.27。这个war文件包含spring conf和java beans以及常规的html等。这个war文件在一个安装在windows平台上的tomcat上成功部署。然而,当试图部署到Linux,以下是显示在tomcat的日志错误:部署Tomcat错误

SEVERE: ContainerBase.addChild: start: 
LifecycleException: Error initializaing : java.lang.IllegalArgumentException: The archive [jar:file:/var/lib/tomcat6/webapps/afghlcustomer.war!/] is malformed and will be ignored: an entry contains an illegal path [/] 
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4217) 
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791) 
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771) 
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526) 
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:905) 
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:525) 
    at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1359) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:297) 
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source) 
    at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source) 
    at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1475) 
    at org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:645) 
    at org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:432) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:640) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:558) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588) 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) 
    at java.lang.Thread.run(Unknown Source) 

请问该如何解决这个问题(和应用程序未部署)?我从哪说起呢?

+0

你是如何构建WAR文件的? – Franklin

+0

@Franklin我正在用蚂蚁和常春藤建立战争档案。你想看看剧本吗? – Khush

+0

作为一个快速修复,您如何直接部署分解文件夹而不是WAR文件。至少你会知道它在Linux上的工作。 – Franklin

回答

0

你可能用JVM命中了一个bug,但我很确定爆炸文件夹应该工作。

+0

我刚试过这个。项目得到部署,但正如我之前所说,他们开始相互冲突。一个项目试图调用另一个春季项目的控制器。 – Khush

+0

我在Windows平台上没有任何此类问题。 – Khush

+0

确定你已经知道这一点,但每个项目都有自己的文件夹在webapp目录中。对!!你还使用Spring Webservices吗?当两个Spring WS应用程序部署在同一个Tomcat上时,我也发生了一次奇怪的冲突。 – Franklin