7

我对 JWS 很陌生。

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

如果我生成一个包含所有使用过的库的 .war 文件并将其放在 webapps 目录中,一切都很好,但是我想共享这些 jars,而 .war 文件本身太大了。

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

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 目录,并将罐子移到那里(我已经删除了 WEB-INF/lib )并且它仍然显示相同的错误 - 似乎tomcat没有在其他任何地方寻找罐子比 WEB-INF/lib 目录。但另一方面 - 为什么创建符号链接会有所作为?

我的 CATALINA_HOME 和 JRE_HOME 变量似乎是正确的。

4

3 回答 3

6

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

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

于 2010-01-20T07:56:20.257 回答
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
于 2010-03-07T13:17:00.793 回答
1

在 Tomcat 6 中,$CATALINA_HOME/libCommon ”类加载器可以使用 的内容(参见http://tomcat.apache.org/tomcat-6.0-doc/class-loader-howto.html)。Tomcat 5.5 以前的shared/lib目录已经不存在了。

但是,我想知道您尝试将哪些罐子放在那里,因为 JAX-WS(或 Metro)的情况是“特殊的”。另外,您使用的是什么JDK?

更新:正如我所说,Metro 的情况有点特殊。要安装它,请将 webservices-rt.jar、webservices-tools.jar、webservices-extra.jar、webservices-extra-api.jar 复制到$CATALINA_HOME/lib. 但是 webservices-api.jar 和 jsr173_api.jar 应该进去$CATALINA_HOME/endorsed。实际上,这就是metro-on-tomcat.xmlmetro 发行版中提供的 ant 脚本的作用(我建议模仿它)。

于 2010-01-20T08:08:19.273 回答