maven 项目配置到tomcat不能正常启动

最近使用IntelliJ IDEA搭建公司项目,该项目是maven项目,加载jar和编译的时候没有任何异常,但是部署到tomcat上之后,就会出现如下异常:

org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/ai]]
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:725)
 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:701)
 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:717)
 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1101)
 at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1786)
 at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
 at java.util.concurrent.FutureTask.run(FutureTask.java:266)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
 at java.lang.Thread.run(Thread.java:745)
Caused by: org.apache.catalina.LifecycleException: Failed to start component [org.apache.catalina.webresources.StandardRoot@695cc4e]
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
 at org.apache.catalina.core.StandardContext.resourcesStart(StandardContext.java:4845)
 at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:4975)
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
 ... 10 more
Caused by: org.apache.catalina.LifecycleException: Failed to initialize component [org.apache.catalina.webresources.JarResourceSet@3b83cbac]
 at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:106)
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:139)
 at org.apache.catalina.webresources.StandardRoot.startInternal(StandardRoot.java:699)
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
 ... 13 more
Caused by: java.lang.IllegalArgumentException: java.util.zip.ZipException: invalid LOC header (bad signature)
 at org.apache.catalina.webresources.JarResourceSet.initInternal(JarResourceSet.java:96)
 at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102)
 ... 16 more
Caused by: java.util.zip.ZipException: invalid LOC header (bad signature)
 at java.util.zip.ZipFile.read(Native Method)
 at java.util.zip.ZipFile.access$1400(ZipFile.java:60)
 at java.util.zip.ZipFile$ZipFileInputStream.read(ZipFile.java:716)
 at java.util.zip.ZipFile$ZipFileInflaterInputStream.fill(ZipFile.java:419)
 at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:158)
 at sun.misc.IOUtils.readFully(IOUtils.java:65)
 at java.util.jar.JarFile.getBytes(JarFile.java:425)
 at java.util.jar.JarFile.getManifestFromReference(JarFile.java:193)
 at java.util.jar.JarFile.getManifest(JarFile.java:180)
 at org.apache.catalina.webresources.JarResourceSet.initInternal(JarResourceSet.java:94)
 ... 17 more

15-Apr-2016 16:56:02.388 SEVERE [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Error deploying web application directory /home/lee/taskmgr/apache-tomcat-8/webapps/ai
 java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/ai]]
 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:729)
 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:701)
 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:717)
 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1101)
 at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1786)
 at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
 at java.util.concurrent.FutureTask.run(FutureTask.java:266)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
 at java.lang.Thread.run(Thread.java:745)

之后再网上google半天,最靠谱的答案就是jar包冲突的问题,但是使用的maven构建的项目,按理不会说出现此问题.重新构建多次,问题依旧没有解决.

后来使用新系统重新搭建环境,包括maven和jdk,在新环境下,该问题就不会出现

根据这个现象,将原系统的maven,重新新建一个repo仓库. 将setting.xml 仓库目录指向该目录,重新maven update该项目的jar.重新编译后问题解决.

记录一下,防止问题再次发生!!

posted @ 2016-06-23 16:10  moon_knight  阅读(21409)  评论(3编辑  收藏  举报