如何在IKVM上运行Jetty?

时间:2011-06-11 00:48:00

标签: jetty ikvm

我是码头的新人。我试图用IKVM运行Jetty。但是,它抛出异常。我不知道该怎么做。

alex@AlexUbuntu:/usr/share/jetty$ ikvm -jar start.jar
5 [main] INFO org.mortbay.log - Logging to org.slf4j.impl.SimpleLogger(org.mortbay.log) via org.mortbay.log.Slf4jLog
java.lang.reflect.InvocationTargetException
    at java.lang.reflect.Method.invoke(Method.java:
    at org.mortbay.start.Main.invokeMain(Main.java:179)
    at org.mortbay.start.Main.start(Main.java:508)
    at org.mortbay.start.Main.start(Main.java:439)
    at org.mortbay.start.Main.main(Main.java:99)
Caused by: cli.System.TypeLoadException: Could not load type 'org.apache.xerces.util.NamespaceSupport' from assembly 'ikvm_dynamic_assembly__40326550, Version=2011.611.1039.16726, Culture=neutral, PublicKeyToken=null'.
    at org.apache.xerces.parsers.XIncludeAwareParserConfiguration.<init>(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:517)
    at java.lang.Class.newInstance0(Class.java:333)
    at java.lang.Class.newInstance(Class.java:320)
    at org.apache.xerces.parsers.ObjectFactory.newInstance(Unknown Source)
    at org.apache.xerces.parsers.ObjectFactory.createObject(Unknown Source)
    at org.apache.xerces.parsers.ObjectFactory.createObject(Unknown Source)
    at org.apache.xerces.parsers.SAXParser.<init>(Unknown Source)
    at org.apache.xerces.parsers.SAXParser.<init>(Unknown Source)
    at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.<init>(Unknown Source)
    at org.apache.xerces.jaxp.SAXParserImpl.<init>(Unknown Source)
    at org.apache.xerces.jaxp.SAXParserFactoryImpl.newSAXParser(Unknown Source)
    at org.mortbay.xml.XmlParser.setValidating(XmlParser.java)
    at org.mortbay.xml.XmlParser.<init>(XmlParser.java:68)
    at org.mortbay.xml.XmlConfiguration.initParser(XmlConfiguration.java)
    at org.mortbay.xml.XmlConfiguration.<init>(XmlConfiguration.java:105)
    at org.mortbay.xml.XmlConfiguration.main(XmlConfiguration.java:958)
    ... 5 more

似乎我需要安装一些外部库才能使其正常工作。但是我需要安装什么。

环境清新干净:

Ubuntu 11.04
IKVM 0.40.0.1
Java 1.6.0_22
Mono 2.6.7

2010年6月28日更新

我想我能让它发挥作用。但我没有尝试在jetty中加载.NET类。顺便说一句,我使用了一种脏方法,我将/usr/bin/java/usr/lib/jvm/default-jvm/java替换为ikvm.exe。所以每当我输入实际上是IKVM的java时。

我将尝试在jetty中加载.NET类。但我不熟悉码头,所以我可能需要一段时间。

2010年7月1日更新

我试图加载.NET类。但是,最后我收到了一条错误消息。

HTTP ERROR 500

Problem accessing /hello/servlet. Reason:

    ikvmstub generated stubs can only be used on IKVM.NET
Caused by:

java.lang.UnsatisfiedLinkError: ikvmstub generated stubs can only be used on IKVM.NET
    at cli.CSharpClass.<init>(Unknown Source)
    at HelloServlet.doPost(HelloServlet.java:28)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:390)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
    at org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:230)
    at org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:326)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:943)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:410)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)

2 个答案:

答案 0 :(得分:0)

你能用'java -jar start.jar'运行Jetty吗?

我怀疑你需要至少一些用于jetty的基本JAR文件,即使它的类加载器动态加载所需的一切。看起来它在日志初始化中失败了。

运行IKVM时,将xerces JAR文件添加到类路径中。

 ikvm -cp .:xerces.jar -jar startup.jar

<强>更新

我只是浏览了jetty.sh,脚本文件设置了一些内容。您需要浏览该文件并确定需要的内容,或者用ikvm替换java的所有实例,并注意Jetty也使用tools.jar

答案 1 :(得分:0)

使用ikvmstub生成的jar文件仅适用于java编译器,不适用于运行时。 java编译器也不能与.NET dll一起使用。对于运行时,您需要直接使用dll。

我们在没有IKVM问题的情况下使用jetty,但我们使用的是更新版本0.46。最简单的方法是使用共享类加载器一步构建所有jar文件。有关详细信息,请参阅ikvm wiki