我在使用 tomcat 5.5 和 tomcat 6.0 服务器时遇到了这个奇怪的问题。我有两个将安装在 tomcat 上的 web 应用程序。当 tomcat 启动时,这两个 web 应用程序也同时启动,但有时一个 web 应用程序由于一个应用程序中的 init 失败而无法初始化,另一个应用程序在运行时出现 classnotfoundexception 错误。在 tomcat 7.0 中,即使其他应用程序无法初始化,该应用程序也可以正常运行。
经过一些调试后,我知道有一个名为 crystal.jar 的 jar,它位于两个应用程序的 web-inf/lib 文件夹中。我已将 jar 移至 tomcat 的 common/lib 文件夹,然后它开始正常工作。我想知道为什么它在 tomcat 7.0 中运行良好,而不是在 tomcat 5.x 和 tomcat 6.x 版本中。这些版本之间的类加载架构是否有任何变化?
谢谢
EDIT1:该库位于两个应用程序 WEB-INF\lib 目录的位置,并且它们与外部 DLLS 没有依赖关系。刚才我阅读了有关 tomcat 5.5 类加载器架构的信息,并了解到每个 Web 应用程序都有自己的类加载器。WEB-INF\lib 文件夹和 classes 文件夹中的库将被加载到这个类加载器中。存储在公共目录下的库将被放置到共享类加载器中。然后这个库应该在 web 应用程序的单独类加载器中单独加载。即使一个 Web 应用程序无法启动,其他 Web 应用程序也应该独立工作。这就是为什么我觉得奇怪,需要进一步调查。