apache-tomcat 6.0.20中的共享jar

时间:2010-01-20 07:47:29

标签: java tomcat java-web-start

我对JWS很陌生。

我想在Linux系统上使用tomcat 6.0.20部署一个Web应用程序(几个Web服务)。

如果我生成一个包含所有已使用库的.war文件并将其放在webapps目录中,那么一切都没问题,但是我想让这些jar共享,而.war文件本身就太大了。

首先我尝试了直观的方式 - 我创建了一个链接(WEB-INF / lib)到包含jar的目录,但奇怪的是它无法部署(如果目录不是链接则启动):

SEVERE: Error configuring application listener of class com.sun.xml.ws.transport.http.servlet.WSServletContextListener
java.lang.ClassNotFoundException: com.sun.xml.ws.transport.http.servlet.WSServletContextListener
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
        at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3877)
        at org.apache.catalina.core.StandardContext.start(StandardContext.java:4429)
        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
        at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:630)
        at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:556)
        at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:491)
        at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
        at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
        at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
        at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
        at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
        at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
        at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
        at org.apache.catalina.core.StandardService.start(StandardService.java:516)
        at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
        at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
        at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

之后我创建了$ CATALINA_HOME / shared / lib目录,并将jar移动到那里(我已经删除了WEB-INF / lib)并且它仍然显示相同的错误 - 似乎tomcat不是在寻找除WEB-INF / lib目录以外的任何地方的jar。但另一方面 - 为什么创建符号链接有什么不同呢?

我的CATALINA_HOME和JRE_HOME vars似乎是正确的。

3 个答案:

答案 0 :(得分:6)

您是否尝试将共享jar文件放在$CATALINA_HOME/lib中?它说“通常情况下,不应该将应用程序类放在这里”,但听起来就像你实际上想要的那样。

$ CATALINA_HOME / shared / lib似乎在6.0中消失了(它在5.5中)。

答案 1 :(得分:4)

在此添加更多细节。

  • metro项目使用共享类加载器,可以将库公开给您部署的所有Web应用程序。
  • metro项目使用Tomcat的认可库机制来更新标准的java发行版

共享类加载器

共享资源在所有Web应用程序之间共享,而不是由Tomcat内部类使用。如果Tomcat 6需要共享库。调整$ CATALINA_HOME / conf / catalina.properties并设置shared.loader = $ {catalina.home} / shared / lib / * .jar

赞同库

要更新java平台并合并包含在标准发行版中的给定库的新版本,可以将库添加到/ lib / endorsed或设置系统范围的属性java.endorsed.dirs如果Tomcat 6需要认可的图书馆。可以使用几种策略来合并所需的背书库

  • 将给定的库添加到java-home / lib / endorsed
  • 设置Tomcat命令行参数-Djava.endorsed.dirs
  • 使用默认目录$ CATALINA_HOME / endorsed;请参阅/bin/setclasspath.sh或/bin/setclasspath.bat
  • 设置系统范围参数JAVA_ENDORSED_DIRS

答案 2 :(得分:1)

在Tomcat 6中,$CATALINA_HOME/lib的内容将可用于“ Common ”类加载器(请参阅http://tomcat.apache.org/tomcat-6.0-doc/class-loader-howto.html)。 Tomcat 5.5过去不存在的shared/lib目录。

但是,我想知道你试图放在哪里的罐子,就像JAX-WS(或Metro)的情况一样“特殊”。另外,你使用的JDK是什么?

更新:正如我所说,Metro的情况有点特殊。要安装它,请在$CATALINA_HOME/lib中复制webservices-rt.jar,webservices-tools.jar,webservices-extra.jar,webservices-extra-api.jar。但是webservices-api.jar和jsr173_api.jar应该进入$CATALINA_HOME/endorsed。实际上,这就是地铁分布中提供的metro-on-tomcat.xml蚂蚁脚本(我建议模仿它)。