7

我尝试将战争部署到 Tomcat 7.0.29 中。我有以下日志堆栈:

GRAVE: Error waiting for multi-thread deployment of context descriptors to complete
java.util.concurrent.ExecutionException: java.lang.StackOverflowError
    at java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:222)
    at java.util.concurrent.FutureTask.get(FutureTask.java:83)
    at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:574)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:470)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1413)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:313)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
    at org.apache.catalina.util.LifecycleBase.setStateInternal(LifecycleBase.java:401)
    at org.apache.catalina.util.LifecycleBase.setState(LifecycleBase.java:346)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1140)
    at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:785)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
    at java.util.concurrent.FutureTask.run(FutureTask.java:138)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)
Caused by: java.lang.StackOverflowError
    at java.util.HashSet.<init>(HashSet.java:86)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2208)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2227)

(省略了许多堆栈帧...)

有人面临同样的问题吗?

4

6 回答 6

4

这在上游报告为 Tomcat 中的问题#53871。问题似乎与注释扫描有关,并且 Tomcat 7.0.38 包含更清晰的错误消息。

从错误报告中:

由于依赖管理问题,我部署了一个 WAR 文件,其中包含两个 JAR 文件,其中包含不同版本的库,其中版本 1 包含从 B 继承的类 A 和另一个版本 2,其中包含从 A 继承的类 B。这些类被加载到这样的顺序 A 和 B 循环地相互继承,这会导致 populateSCIsForCacheEntry 中的堆栈溢出,因为它没有检测到继承树中的循环。

这正是我的问题所在:旧版本dom4j捆绑了不兼容的jaxen. 7.0.38 中的新错误诊断准确显示了哪些类形成了循环,我通过升级这些依赖项来修复它。

于 2013-03-25T09:42:48.263 回答
2

我在 Tomcat 7.0 中也遇到了这个问题。29和 Tomcat 7.0。30 . 但是使用 Tomcat 7.0。28一切正常,所以我怀疑这是最近引入的 Tomcat 问题。

在 7.0 中遇到的错误。29和 7.0。30、启动Tomcat并部署war文件时:

14:01:06,380 ERROR [HostConfig:576] Error waiting for multi-thread deployment of context descriptors to complete java.util.concurrent.ExecutionException: java.lang.StackOverflowError
    at java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:252)
    at java.util.concurrent.FutureTask.get(FutureTask.java:111)
    at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:574)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:470)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1413)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:313)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
    at org.apache.catalina.util.LifecycleBase.setStateInternal(LifecycleBase.java:401)
    at org.apache.catalina.util.LifecycleBase.setState(LifecycleBase.java:346)
    at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:1140)
    at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:785)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
    at java.util.concurrent.FutureTask.run(FutureTask.java:166)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
    at java.lang.Thread.run(Thread.java:722)
Caused by: java.lang.StackOverflowError
    at java.util.HashSet.<init>(HashSet.java:103)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2243)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2260)
    at org.apache.catalina.startup.ContextConfig.populateSCIsForCacheEntry(ContextConfig.java:2260)
于 2012-09-14T11:51:30.927 回答
1

使用较低版本的Tomcat。您使用的Tomcat版本存在问题。

于 2013-03-28T09:10:43.710 回答
1

一种解决方法:我更改了WAR的名称(pom.xml 中没有 finalName 并更改了工件版本)并且它有效....为什么?我到现在都不知道!

一个真正的和真正的解决方案?绝对是一个新的Tomcat版本。. .

于 2012-11-13T14:45:42.300 回答
1

对我来说,当我将应用程序上下文设置为与 .pom 文件中的 Maven atrifactId 相同的名称时,这种行为在 IntelliJ Idea 中重现。例如,我的 artifactId 是“test”,然后我将应用程序上下文(编辑配置 -> Tomcat 服务器 -> 部署,选择分解的工件)设置为“/test”。一旦我更改了应用程序上下文,一切正常。

于 2012-11-28T20:24:21.210 回答
1

我有同样的问题。我认为它是由Tomcat 7引起的,所以当我更改为Tomcat 6.0.35时,问题像魅力一样自行解决。

于 2013-11-01T06:15:29.150 回答