tomcat启动报错:Unable to complete the scan for annotations for web application [] due to a StackOverflow

问题描述

启动tomcat报错:

org.apache.catalina.startup.HostConfig.deployDescriptor Deploying deployment descriptor [/api/apache-tomcat-8.5.77/conf/Catalina/localhost/api.xml]
09-Dec-2022 15:48:58.761 SEVERE [localhost-startStop-1] org.apache.catalina.core.ContainerBase.addChildInternal ContainerBase.addChild: start: 
	org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/api]]
		at org.apache.catalina.util.LifecycleBase.handleSubClassException(LifecycleBase.java:440)
		at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:198)
		at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:753)
		at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:727)
		at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:695)
		at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:673)
		at org.apache.catalina.startup.HostConfig$DeployDescriptor.run(HostConfig.java:1881)
		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:1149)
		at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
		at java.lang.Thread.run(Thread.java:748)
	Caused by: java.lang.IllegalStateException: Unable to complete the scan for annotations for web application [/api] 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.bouncycastle.asn1.ASN1EncodableVector->org.bouncycastle.asn1.DEREncodableVector->org.bouncycastle.asn1.ASN1EncodableVector]
		at org.apache.catalina.startup.ContextConfig.checkHandlesTypes(ContextConfig.java:2072)
		at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:2010)
		at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1962)
		at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1932)
		at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1888)
		at org.apache.catalina.startup.ContextConfig.processClasses(ContextConfig.java:1186)
		at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1093)
		at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:779)
		at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:299)
		at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
		at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5130)
		at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
		... 10 more


原因分析:

Caused by: java.lang.IllegalStateException: Unable to complete the scan for annotations for web application [/wrs] due to a StackOverflowError

报错为Java虚拟机栈溢出问题

The class hierarchy being processed was [org.bouncycastle.asn1.ASN1EncodableVector->org.bouncycastle.asn1.DEREncodableVector->org.bouncycastle.asn1.ASN1EncodableVector]

导致栈溢出的根本原因是由于包含(ASN1EncodableVector)jar包冲突,这种情况是有两个jar都含有上述相同的类名,且继承关系刚好相反,故造成tomcat启动的环问题。


解决方案:

在项目中找到含有 ASN1EncodableVector 的jar包删除(如 bcprov-jdk14-1.38.jar),重启tomcat即可。

创作不易,关注💖、点赞👍、收藏🎉就是对作者最大的鼓励👏,欢迎在下方评论留言🧐

"Unable to locate the Javac Compiler"是一个错误消息,表明在编译Java代码时找不到Javac编译器。这个问题通常出现在两种情况下:一是没有正确安装Java JDK,二是没有设置正确的JAVA_HOME环境变量。 引用和引用中的错误消息提示了可能的原因和解决方法。首先,确保你已经安装了Java JDK,并且版本是1.4或以上。你可以通过检查Java安装目录下是否有tools.jar文件来确认是否安装了完整的JDK。 如果已经正确安装了JDK,那么问题可能是由于没有设置正确的JAVA_HOME环境变量导致的。你可以通过设置JAVA_HOME环境变量来告诉系统JDK的安装路径。具体设置方法取决于你使用的操作系统。在Windows系统中,你可以按照以下步骤设置环境变量: 1. 打开控制面板,并选择系统和安全。 2. 点击系统,然后点击高级系统设置。 3. 在系统属性窗口中,点击环境变量。 4. 在用户变量或系统变量中,找到名为JAVA_HOME的变量(如果没有则创建)。 5. 设置JAVA_HOME的值为JDK的安装路径,比如C:\Program Files\Java\jdk1.8.0_111。 6. 确认设置并关闭窗口。 在Mac或Linux系统中,你可以编辑.bash_profile或.bashrc文件,并在其中添加以下行: ``` export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_111.jdk/Contents/Home export PATH=$JAVA_HOME/bin:$PATH ``` 保存文件并退出,然后执行"source .bash_profile"或"source .bashrc"命令使环境变量生效。 一旦你安装了JDK并设置了JAVA_HOME环境变量,你应该能够解决"Unable to locate the Javac Compiler"的问题。如果问题仍然存在,你可以尝试重新安装JDK或查找其他解决方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Unable to locate the Javac Compiler in 错误的解决办法之一](https://blog.csdn.net/wangming1473/article/details/72781679)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [[ERROR] Unable to locate the Javac Compiler in: [ERROR] /Library/Internet Plug-Ins/JavaAppletPlugi](https://blog.csdn.net/nonolive/article/details/113505370)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.猫的树

你的鼓励就是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值