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

 更新时间:2023年07月17日 10:59:03   作者:摆烂的小趴菜  
这篇文章主要介绍了关于Tomcat启动失败报循环依赖的问题解决(AncestorAxisIterator),Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,需要的朋友可以参考下

异常堆栈

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的这个包排掉,重启,果然项目又双叒正常启动了。

总结

Jaxen包和dom4j包在使用时候有些依赖关系,如果必须同时引入两个包的话,要注意两者相互的版本关系,如果版本不对应可能会导致文章开始的循环依赖问题。

目前本人亲测,Jaxen-1.1.6和dom4j-1.6.1这两个版本搭配不会有循环依赖的问题出现。

到此这篇关于关于Tomcat启动失败报循环依赖的问题解决(AncestorAxisIterator)的文章就介绍到这了,更多相关Tomcat启动失败问题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 安装为 window 服务的tomcat修改jvm内存的两种方法

    安装为 window 服务的tomcat修改jvm内存的两种方法

    这篇文章主要介绍了安装为 window 服务的tomcat修改jvm内存,本文通过两种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • 通过图文讲解Tomcat部署war包的方法步骤

    通过图文讲解Tomcat部署war包的方法步骤

    Tomcat是目前web开发中非常流行的Web服务器,下面这篇文章主要给大家介绍了关于如何通过图文讲解Tomcat部署war包的方法步骤,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • 解决Tomcat报404问题大全(包括tomcat可以正常运行但是报404)

    解决Tomcat报404问题大全(包括tomcat可以正常运行但是报404)

    这篇文章主要介绍了解决Tomcat报404问题大全(包括tomcat可以正常运行但是报404),本文给大家介绍非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • idea中没有tomcat选项如何配置添加tomcat

    idea中没有tomcat选项如何配置添加tomcat

    多的工程用IDEA打开调试,如果用到 tomcat服务,都要配置一下,本文主要介绍了idea中没有tomcat选项如何配置添加tomcat,下面就来具体介绍一下,感兴趣的可以了解一下
    2024-05-05
  • 教你在IDEA中使用Tomcat部署并启动Web项目

    教你在IDEA中使用Tomcat部署并启动Web项目

    这篇文章主要介绍了教你在IDEA中使用Tomcat部署并启动Web项目,IDEA作为一款主流的开发工具其实已经集成了Tomcat的部分功能,需要的朋友可以参考下
    2023-03-03
  • Tomcat中的Session与Cookie深入讲解

    Tomcat中的Session与Cookie深入讲解

    这篇文章主要给大家介绍了关于Tomcat中Session与Cookie的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Tomcat具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • 对一个tomcat实现多端口、多域名访问的方法

    对一个tomcat实现多端口、多域名访问的方法

    这篇文章主要是介绍如何在tomcat中进行配置,使同一个应用可以通过不同的端口号进行访问。大家可能都遇到过,在某些需要进行安全控制的场景中会应用到,例如:不同地址段只能通过某个端口访问。下面通过这篇文章来详细学习下吧,有需要的可以参考借鉴。
    2016-11-11
  • 怎么减少本地调试tomcat重启次数你知道吗

    怎么减少本地调试tomcat重启次数你知道吗

    这篇文章主要为大家详细介绍了怎么减少本地调试tomcat重启次数,使用Groovy,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • Tomcat使用https配置实战教程

    Tomcat使用https配置实战教程

    这篇文章主要介绍了Tomcat使用https配置实战,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • 配置tomcat内存大小全过程(windows、linux)

    配置tomcat内存大小全过程(windows、linux)

    本文详细介绍了Java虚拟机(JVM)内存参数的设置方法,包括初始堆内存(-Xms)和最大堆内存(-Xmx),以及非堆内存(PermSize和MaxPermSize)的配置,同时,提供了在Windows和Linux服务器上配置JVM内存的具体步骤,并介绍了如何查看配置是否生效以及解决配置无效的问题
    2024-11-11

最新评论