使用Jetty 9作为Java 9模块会产生ClassNotFoundException

使用Jetty 9作为Java 9模块会产生ClassNotFoundException,java,jetty,java-9,java-module,Java,Jetty,Java 9,Java Module,我在Java 9中使用jetty 9.4.8.v20171121,下面是我加载的jetty模块列表: jetty-server-9.4.8.v20171121.jar jetty-servlet-9.4.8.v20171121.jar jetty-servlets-9.4.8.v20171121.jar jetty-util-9.4.8.v20171121.jar jetty-xml-9.4.8.v20171121.jar jetty-http-9.4.8.v20171121.jar

我在Java 9中使用jetty 9.4.8.v20171121,下面是我加载的jetty模块列表:

jetty-server-9.4.8.v20171121.jar
jetty-servlet-9.4.8.v20171121.jar
jetty-servlets-9.4.8.v20171121.jar 
jetty-util-9.4.8.v20171121.jar   
jetty-xml-9.4.8.v20171121.jar 
jetty-http-9.4.8.v20171121.jar   
jetty-io-9.4.8.v20171121.jar 
jetty-security-9.4.8.v20171121.jar   
jetty-webapp-9.4.8.v20171121.jar
这是我启动Jetty的代码:

Server server = new Server( 8080 );
WebAppContext webapp = new WebAppContext();
webapp.setContextPath( "/" );
File warFile = new File(
        "/home/Sam/WebServer/jar/org.test.site.fend-0.1.0-SNAPSHOT.war" );
if (!warFile.exists())
{
    throw new RuntimeException( "Unable to find WAR File: "
            + warFile.getAbsolutePath() );
}
webapp.setWar( warFile.getAbsolutePath() );
webapp.setExtractWAR(true);
webapp.setAttribute(
        "org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern",
        ".*/[^/]*servlet-api-[^/]*\\.jar$|.*/javax.servlet.jsp.jstl-.*\\.jar$|.*/[^/]*taglibs.*\\.jar$" );
server.setHandler( webapp );
server.start();
server.dumpStdErr();
这就是我得到的:

2018-02-06 17:18:03:111 [main] DEBUG org.eclipse.jetty.util.component.AbstractLifeCycle - starting o.e.j.w.WebAppContext@659499f1{/,null,UNAVAILABLE}{/home/Sam/WebServer/jar/org.test.site.fend-0.1.0-SNAPSHOT.war}
2018-02-06 17:18:03:115 [main] WARN org.eclipse.jetty.webapp.WebAppContext - Failed startup of context o.e.j.w.WebAppContext@659499f1{/,null,UNAVAILABLE}{/home/Sam/WebServer/jar/org.test.site.fend-0.1.0-SNAPSHOT.war}
java.lang.ClassNotFoundException: org.eclipse.jetty.webapp.WebInfConfiguration
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:582)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:185)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:496)
    at jetty.util@9.4.8.v20171121/org.eclipse.jetty.util.Loader.loadClass(Loader.java:65)
    at jetty.webapp@9.4.8.v20171121/org.eclipse.jetty.webapp.WebAppContext.loadConfigurations(WebAppContext.java:1035)
    at jetty.webapp@9.4.8.v20171121/org.eclipse.jetty.webapp.WebAppContext.preConfigure(WebAppContext.java:473)
    at jetty.webapp@9.4.8.v20171121/org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:544)
    at jetty.util@9.4.8.v20171121/org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
    at jetty.util@9.4.8.v20171121/org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:133)
    at jetty.server@9.4.8.v20171121/org.eclipse.jetty.server.Server.start(Server.java:418)
    at jetty.util@9.4.8.v20171121/org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:107)
    at jetty.server@9.4.8.v20171121/org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:113)
    at jetty.server@9.4.8.v20171121/org.eclipse.jetty.server.Server.doStart(Server.java:385)
    at jetty.util@9.4.8.v20171121/org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68)
如何修复它?

Jetty 9.x的JAR(无论子版本如何)不可用

为了让Jetty正确地支持JPMS,它需要对包装进行根本性的更改,并且肯定会影响Jetty代码库的主要部分

注意:如果您希望看到Jetty完全符合JPMS,请对此问题发表评论

在Jetty的JPMS工作能够认真进行之前,还有一些事情需要解决

  • JEP238(多版本JAR)如何处理ServiceLoader行为?(提示:目前没有)
  • 注释/字节码扫描在模块环境中如何工作?(目前的想法是,我们需要实现与JPMS相同的可见性规则,只扫描相关方范围内的内容:webapp或服务器)
  • 至于Jetty何时将支持JPMS,这在Jetty 9.x中不太可能发生,我们对Jetty 10.x进行了简要讨论,但确定支持Servlet 4.0、javax.websocket 1.1和Java8仍然很重要

    一旦Java8完全结束,将现有的稳定分支迁移到JPMS的过程就有效了。(如果会发生这种情况,则是另一个问题)


    我们正在密切关注规范组的开放性问题,并将Java11(LTS)版本作为JPMS支持的一个很好的候选版本。这很可能与Jetty 11.x(目前理论上)一致。

    Jetty 9.4.8的JAR不是JPMS模块。也许未来的Jetty 10.x(或者更可能的Jetty 11.x)将是第一个JPMS Jetty发行版。不知道多久,正确地支持JPMS将需要对我们的包装进行彻底的更改,并且肯定会影响代码库的主要部分。还有JPMS规范中关于JEP238和ServiceLoader行为如何工作的缺失部分。因此,嗯,至少在Java11之前不太可能看到Jetty+JPMS的发布。在使用JPMS时,也不支持注释/字节码扫描(Jetty开发人员知道)。欢迎在@JoakimErdfelt上打开一个问题,询问这方面的问题,并发表一些很好的评论,但这些评论包含在一个答案中是非常有用的。JPMS支持问题-