启动Jetty服务器时扫描条目"module-info.class"出错。

27

最近我在启动Java服务器时看到了这个问题。有人还遇到过这个问题吗?如果是,有什么解决方法? 我可以确认相关路径中存在jar和module-info.class。

 MultiException[java.lang.RuntimeException: Error scanning entry module-info.class from jar
 file:jetty/9.2.4.v20141103/tempDirectory/webapp/WEB-INF/lib/slf4j-api-1.8.0-alpha2.jar, java.lang.RuntimeException: Error scanning entry module-info.class from jar
 file:jetty/9.2.4.v20141103/tempDirectory/webapp/WEB-INF/lib/log4j-over-slf4j-1.8.0-alpha2.jar, java.lang.RuntimeException: Error scanning entry module-info.class from jar
 file:jetty/9.2.4.v20141103/tempDirectory/webapp/WEB-INF/lib/jcl-over-slf4j-1.8.0-alpha2.jar] at
 org.eclipse.jetty.annotations.AnnotationConfiguration.scanForAnnotations(AnnotationConfiguration.java:535) at
 org.eclipse.jetty.annotations.AnnotationConfiguration.configure(AnnotationConfiguration.java:446) at
 org.eclipse.jetty.webapp.WebAppContext.configure(WebAppContext.java:473) at
 org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1331) at
 org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:741) at
 org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:499) at
 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) at
 org.eclipse.jetty.deploy.bindings.StandardStarter.processBinding(StandardStarter.java:41) at
 org.eclipse.jetty.deploy.AppLifeCycle.runBindings(AppLifeCycle.java:186) at
 org.eclipse.jetty.deploy.DeploymentManager.requestAppGoal(DeploymentManager.java:498) at
 org.eclipse.jetty.deploy.DeploymentManager.addApp(DeploymentManager.java:146) at
 org.eclipse.jetty.deploy.providers.ScanningAppProvider.fileAdded(ScanningAppProvider.java:180) at
 org.eclipse.jetty.deploy.providers.ScanningAppProvider$1.fileAdded(ScanningAppProvider.java:64) at 
 org.eclipse.jetty.util.Scanner.reportAddition(Scanner.java:609) at 
 org.eclipse.jetty.util.Scanner.reportDifferences(Scanner.java:528) at
 org.eclipse.jetty.util.Scanner.scan(Scanner.java:391) at
 org.eclipse.jetty.util.Scanner.doStart(Scanner.java:313) at
 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) at
 org.eclipse.jetty.deploy.providers.ScanningAppProvider.doStart(ScanningAppProvider.java:150) at
 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) at
 org.eclipse.jetty.deploy.DeploymentManager.startAppProvider(DeploymentManager.java:560) at
 org.eclipse.jetty.deploy.DeploymentManager.doStart(DeploymentManager.java:235) at
 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) at
 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:132) at 
 org.eclipse.jetty.server.Server.start(Server.java:387) at
 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:114) at
 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:61) at 
 org.eclipse.jetty.server.Server.doStart(Server.java:354) at
 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) at
 org.eclipse.jetty.xml.XmlConfiguration$1.run(XmlConfiguration.java:1255) at 
 java.security.AccessController.doPrivileged(Native Method)     at
 org.eclipse.jetty.xml.XmlConfiguration.main(XmlConfiguration.java:1174) at 
 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at
 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at
 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at
 java.lang.reflect.Method.invoke(Method.java:483) at
 org.eclipse.jetty.start.Main.invokeMain(Main.java:323) at
 org.eclipse.jetty.start.Main.start(Main.java:820) at
 org.eclipse.jetty.start.Main.main(Main.java:112)

欢迎来到StackOverflow!你目前尝试了什么?展示一下你的工作吧。 :) - Nathan Arthur
我尝试使用早期版本的slf,如果我使用1.7.9版本,它可以正常工作。 - Puliyur ranganath
什么是Jetty版本?还有Java 7、8吗? - David Pérez Cabrera
jetty 9.2.4.v20141103;java 8 - Puliyur ranganath
你能否发布你的 build.gradle 文件吗?这会有所帮助。 - David Pérez Cabrera
显示剩余3条评论
1个回答

27

module-info.class是Java9 (JPMS)的特性。

Jetty 9.4.9(或更高版本)支持Java 9中的新JAR文件更改。

无论您使用什么运行时JVM(Oracle Java 8,甚至是OpenJDK 11.0.3),如果您在WebApp(或服务器类加载器)中使用JEP-238 Multi-Release Jar files,则必须将Jetty版本升级到Jetty 9.4.x。

这是因为Servlet 3.x引入了字节码扫描要求。 Jetty需要扫描所有JAR文件,以寻找可能与您的WebApp定义的@HandlesTypes匹配的servlet注释或引用。一旦JEP-238成为现实,这个字节码扫描层就必须适应/更新/修复以支持这些新的JAR文件结构。Jetty 9.4.9是第一个在字节码扫描期间支持这些新JAR文件结构的Jetty版本。

有关Java 9功能的问题:


Jetty什么时候支持JDK 9? - Pavel_K
1
@Pavel_K - 答案已经更新,表示Jetty 9.4.x支持JDK 9。此外,使用JDK 9并不重要-我正在使用JDK 8,但仍然遇到了问题,因为我拉取的某些jar是针对JDK 9构建的。 - ArtOfWarfare
我们正在面临这个问题。详细日志显示“从jar文件:///privare/var/folders/8n/x2m8yc21/xxx扫描条目META-INF/versions/9/module-info.class时出错”,Jetty版本为9.4.6。根据@Joakim的答案,我们需要升级到9.4.9+版本。 - lawrence
@劳伦斯请注意安全报告 - https://www.eclipse.org/jetty/security-reports.html,以及现在可用的版本 - https://www.eclipse.org/jetty/documentation/current/what-jetty-version.html。 - Joakim Erdfelt
我遇到了这个问题。在嵌入式Jetty 9.2.1中运行应用程序时没有出现任何错误,但是独立的Jetty却出现了这个错误。我也使用了JDK 8。你知道这是怎么发生的吗? - Abhi
1
@Abhi 简单来讲,嵌入式Jetty不会执行字节码扫描,除非您已经添加了特定的配置。而独立版始终执行字节码扫描。 - Joakim Erdfelt

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接