您当前的位置:首页 > 网站建设 > 网站维护
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery |

关于Tomcat启动失败报循环依赖的问题解决(AncestorAxisIterator)

51自学网 2023-08-14 21:11:57
  网站维护

异常堆栈

Tomcat启动失败报循环依赖(AncestorAxisIterator-AncestorOrSelfAxisIterator)

严重: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]]        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:162)        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:753)        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:729)        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:717)        at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:587)        at org.apache.catalina.startup.HostConfig$DeployDescriptor.run(HostConfig.java:1798)        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)        at java.util.concurrent.FutureTask.run(FutureTask.java:266)        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)        at java.lang.Thread.run(Thread.java:745)Caused by: java.lang.IllegalStateException: Unable to complete the scan for annotations for web application [] due to a StackOverflowError. Possible root causes include a too low setting for -Xss and illegal cyclic inheritance dependencies. The class hierarchy being processed was [org.jaxen.util.AncestorAxisIterator->org.jaxen.util.AncestorOrSelfAxisIterator->org.jaxen.util.AncestorAxisIterator]        at org.apache.catalina.startup.ContextConfig.checkHandlesTypes(ContextConfig.java:2108)        at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:2054)        at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1999)        at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1969)        at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1923)        at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1166)        at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:783)        at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:307)        at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:95)        at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5213)        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145)        ... 10 more

tomcat在日常启动时候突然爆出了这个错误,爆出org.jaxen.util.AncestorAxisIterator类和org.jaxen.util.AncestorOrSelfAxisIterator循环依赖的问题,但是我合的代码只有一行赋值代码啊,所以断定这个肯定不是我的代码原因,但是测试环境因为这个启不来,出于大佬的心态,我觉得着手解决这个问题。

第一步:解决冲突

看见这个问题,第一时间当然是认为包冲突拉,那我们第一时间拉出maven helper 来看看这个类所属的包是不是有冲突了。如下图所示:

在这里插入图片描述

这里边这个包只是被一个同事引得其他包使用了,并没有多个版本混杂的情况,这就尴尬了。那么这个问题从何而来呢?

第二步:寻找思路

是tomcat的配置问题,正巧我司项目最近升级了tomcat的版本,没准真是这个问题呢,于是乎我更改了tomcat的配置。

你别说,改完还真启起来了,于是乎解决了这个疑难杂症的我美滋滋的睡觉去了。 但是第二天tomcat在重启的时候又挂了,一模一样的原因,于是乎我意识到,问题没有这么简单,一定是某个隐藏的包冲突了没有显示出来。于是我又看到了上述文章的最后一行提示。

百度了一下更改jar可以使用,我已经把我的更新为Jaxen-1.2.0和dom4j-1.6.1两个jar包 问题还是会出现 解决方案是更新jar包,更新Jaxen-1.1.6和dom4j-1.6.1两个jar包 ------还有待测试

我一看,要不我测试测试试试?于是我查了下我这两个包的版本。Jaxen-1.1.6刚开始排查过了不用看了,看看第二个包吧,果不其然:

在这里插入图片描述

于是把下边1.1的这个包排掉,重启,果然项目又双
下载地址:
详解如何在Nginx中设置文件上传大小限制
linux如何查看nginx启动路径

51自学网自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1