Tomcat 9 NoSuchFileException 在 WEB-INF/lib 中,但文件存在

问题描述 投票:0回答:1

我正在运行 Tomcat 9、Java 11 并部署 Spring Boot 应用程序。

应用程序已成功部署,但我收到 404 响应。查看 Tomcat 日志,它说找不到 JAR,但如果我在 WEB-INF/lib 下找到文件 spring-messaging-5.3.29.jar,它实际上就在那里。

那么这可能是什么原因呢?

编辑:如果我重新部署应用程序,它会显示另一个 JAR spring-boot-starter-data-jpa-2.7.14.jar。我想,这里总体上有些东西被破坏了。

感谢您的回复!

[Catalina-utility-1] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class [ch.qos.logback.classic.$
        java.lang.IllegalStateException: java.io.IOException: java.lang.reflect.InvocationTargetException
                at org.apache.catalina.webresources.AbstractSingleArchiveResourceSet.getArchiveEntry(AbstractSingleArchiveResourceSet.java:101)
                at org.apache.catalina.webresources.AbstractArchiveResourceSet.getResource(AbstractArchiveResourceSet.java:256)
                at org.apache.catalina.webresources.StandardRoot.getResourceInternal(StandardRoot.java:282)
                at org.apache.catalina.webresources.Cache.getResource(Cache.java:62)
                at org.apache.catalina.webresources.StandardRoot.getResource(StandardRoot.java:217)
                at org.apache.catalina.webresources.StandardRoot.getClassLoaderResource(StandardRoot.java:226)
                at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2303)
                at org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:865)
                at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1334)
                at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1188)
                at ch.qos.logback.core.ContextBase.getLifeCycleManager(ContextBase.java:260)
                at ch.qos.logback.core.ContextBase.reset(ContextBase.java:175)
                at ch.qos.logback.classic.LoggerContext.reset(LoggerContext.java:220)
                at ch.qos.logback.classic.LoggerContext.stop(LoggerContext.java:348)
                at ch.qos.logback.classic.servlet.LogbackServletContextListener.contextDestroyed(LogbackServletContextListener.java:36)
                at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4730)
                at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5396)
                at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:257)
                at org.apache.catalina.core.ContainerBase.removeChild(ContainerBase.java:805)
                at org.apache.catalina.startup.HostConfig.undeploy(HostConfig.java:1424)
                at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1351)
                at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1610)
                at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:305)
                at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
                at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1151)
                at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1353)
                at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1357)
at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1335)
                at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
                at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305)
                at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
                at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
                at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
                at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
                at java.base/java.lang.Thread.run(Thread.java:829)
        Caused by: java.io.IOException: java.lang.reflect.InvocationTargetException
                at org.apache.tomcat.util.compat.Jre9Compat.jarFileNewInstance(Jre9Compat.java:236)
                at org.apache.tomcat.util.compat.JreCompat.jarFileNewInstance(JreCompat.java:162)
                at org.apache.catalina.webresources.AbstractArchiveResourceSet.openJarFile(AbstractArchiveResourceSet.java:307)
                at org.apache.catalina.webresources.AbstractSingleArchiveResourceSet.getArchiveEntry(AbstractSingleArchiveResourceSet.java:97)
                ... 34 more
        Caused by: java.lang.reflect.InvocationTargetException
                at java.base/jdk.internal.reflect.GeneratedConstructorAccessor7.newInstance(Unknown Source)
                at java.base/jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
                at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:490)
                at org.apache.tomcat.util.compat.Jre9Compat.jarFileNewInstance(Jre9Compat.java:233)
                ... 37 more
        Caused by: java.nio.file.NoSuchFileException: /var/lib/tomcat9/webapps/spring-boot/WEB-INF/lib/spring-messaging-5.3.29.jar
                at java.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:92)
                at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:111)
                at java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:116)
                at java.base/sun.nio.fs.UnixFileAttributeViews$Basic.readAttributes(UnixFileAttributeViews.java:55)
                at java.base/sun.nio.fs.UnixFileSystemProvider.readAttributes(UnixFileSystemProvider.java:149)
                at java.base/sun.nio.fs.LinuxFileSystemProvider.readAttributes(LinuxFileSystemProvider.java:99)
                at java.base/java.nio.file.Files.readAttributes(Files.java:1764)
at java.base/java.util.zip.ZipFile$Source.get(ZipFile.java:1259)
                at java.base/java.util.zip.ZipFile$CleanableResource.<init>(ZipFile.java:733)
                at java.base/java.util.zip.ZipFile$CleanableResource.get(ZipFile.java:850)
                at java.base/java.util.zip.ZipFile.<init>(ZipFile.java:248)
                at java.base/java.util.zip.ZipFile.<init>(ZipFile.java:177)
                at java.base/java.util.jar.JarFile.<init>(JarFile.java:350)
                ... 41 more
spring-boot tomcat9
1个回答
0
投票

最后,我通过将正确的Java版本放入

pom.xml
中解决了这个问题:

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.release>11</maven.compiler.release>  <!-- Java version -->
    <tomcat.version>9.0.31</tomcat.version>
</properties>
© www.soinside.com 2019 - 2024. All rights reserved.