2011-11-14 211 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