0

我有一个使用 jodd 3.6.6 构建的应用程序,当我尝试在 jetty9 上运行它时,它无法初始化 Madvoc:

    1377 [ERROR] j.m.Madvoc.startNewWebApplication:161 - Madvoc startup failure.
jodd.madvoc.MadvocException: Scan classpath error; <--- java.lang.ClassNotFoundException: Class not found: org.eclipse.jetty.client.api.Result
    at jodd.madvoc.config.AutomagicMadvocConfigurator.configure(AutomagicMadvocConfigurator.java:85)
    at jodd.madvoc.config.AutomagicMadvocConfigurator.configure(AutomagicMadvocConfigurator.java:65)
    at jodd.madvoc.WebApplication.configure(WebApplication.java:255)
    at jodd.madvoc.Madvoc.start(Madvoc.java:238)
    at jodd.madvoc.Madvoc.startNewWebApplication(Madvoc.java:157)
    at jodd.madvoc.MadvocServletFilter.init(MadvocServletFilter.java:45)
    at org.eclipse.jetty.servlet.FilterHolder.initialize(FilterHolder.java:138)
    at org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.java:852)
    at org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:298)
    at org.eclipse.jetty.webapp.WebAppContext.startWebapp(WebAppContext.java:1349)
    at org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1342)
    at org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:741)
    at org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:505)
    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 net.sourceforge.eclipsejetty.starter.jetty9.Jetty9Adapter.start(Jetty9Adapter.java:68)
    at net.sourceforge.eclipsejetty.starter.common.AbstractJettyLauncherMain.launch(AbstractJettyLauncherMain.java:85)
    at net.sourceforge.eclipsejetty.starter.jetty9.Jetty9LauncherMain.main(Jetty9LauncherMain.java:42)
Caused by: jodd.io.findfile.FindFileException: Scan entry error: EntryData{org.eclipse.jetty.client.api.Result'}; <--- java.lang.ClassNotFoundException: Class not found: org.eclipse.jetty.client.api.Result
    at jodd.io.findfile.ClassFinder.scanEntry(ClassFinder.java:391)
    at jodd.io.findfile.ClassFinder.scanJarFile(ClassFinder.java:292)
    at jodd.io.findfile.ClassFinder.scanPath(ClassFinder.java:261)
    at jodd.io.findfile.ClassFinder.scanPaths(ClassFinder.java:226)
    at jodd.madvoc.config.AutomagicMadvocConfigurator.configure(AutomagicMadvocConfigurator.java:83)
    ... 22 more
Caused by: jodd.madvoc.MadvocException: Invalid Madvoc result class: org.eclipse.jetty.client.api.Result; <--- java.lang.ClassNotFoundException: Class not found: org.eclipse.jetty.client.api.Result
    at jodd.madvoc.config.AutomagicMadvocConfigurator.onEntry(AutomagicMadvocConfigurator.java:108)
    at jodd.io.findfile.ClassFinder.scanEntry(ClassFinder.java:389)
    ... 26 more

相同的应用程序在 tomcat 上运行没有问题。任何想法 ?

4

1 回答 1

0

好的,应该很简单:跳过对netty类的扫描。

解释如下:在 Madvoc 中,您可以选择使用Result类()来处理结果(文档)。简而言之,如果您有一个带Result类型的字段,Madvoc 将使用它来实现此功能。

所以看起来 Netty 具有相同的类名,因此出现了错误。为了防止这种情况(直到我们做出更好的识别),只需跳过扫描完整的类路径,让扫描仪只扫描你的类——这也将提高启动性能。以下是如何做到这一点:

默认情况下,AutomagicMadvocConfigurator用于配置操作(通过扫描路径)。获取这个实例(WebApplication例如)并配置它(因为它是一个ClassFinder子类)。所以我要做的是:

classFinder.setExcludeAllEntries(true);
classFinder.setIncludedEntries(myapp.getClass().getPackage().getName() + ".*");
classFinder.setIncludedJars("somejar.jar", "myapp*.jar");

这将缩小正在搜索的类路径。

如果您需要更多帮助,请告诉我。同时,我们一定会做出改变,这样就不会再发生了!

于 2015-06-07T20:34:06.197 回答