13.Tomcat服务器启动失败的总结

article/2025/8/31 2:55:59

目录

一、Tomcat服务器启动失败。

(1)找原因:看最后一个Caused by:后面的内容。

(2)解决:我是直接删除"java.html",然后可运行。 

二、Tomcat工件部署出错。

(1)错误原因1:javax.servlet.ServletContextListener。

(1)解决方法一:换一个版本的Tomcat。

(2) 解决方法二:在pom.xml文件中添加标签

(3) 解决方法三:Put into Output Root

(2)出错原因2:NotWritablePropertyException: Invalid property 'jdbcTemplate' of bean class [dao.impl.UserDaoImpl]。

(1)错误:类没有设置setter方法。

(2)解决方法:在pom.xml文件中war。

三、Tomcat服务器启动时的日志是乱码。

(1)解决方法1-环境变量。

(2)解决方法2-tomcat配置VM-options。

(3)解决方法3-IEDA配置VM-options。

 (4)解决乱码后的显示。 


一、Tomcat服务器启动失败。

...................省略大量上面的内容Caused by: java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: 子容器启动失败at java.base/java.util.concurrent.FutureTask.report(FutureTask.java:122)at java.base/java.util.concurrent.FutureTask.get(FutureTask.java:191)at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:926)... 13 moreCaused by: org.apache.catalina.LifecycleException: 子容器启动失败at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:938)at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:886)at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1396)at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1386)at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:140)at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:919)... 13 moreCaused by: java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: 无法启动组件[org.apache.catalina.webresources.StandardRoot@12a94400]at java.base/java.util.concurrent.FutureTask.report(FutureTask.java:122)at java.base/java.util.concurrent.FutureTask.get(FutureTask.java:191)at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:926)... 21 moreCaused by: org.apache.catalina.LifecycleException: 无法启动组件[org.apache.catalina.webresources.StandardRoot@12a94400]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.StandardContext.resourcesStart(StandardContext.java:4834)at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:4972)at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1396)at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1386)at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)at java.base/java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:140)at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:919)... 21 moreCaused by: java.lang.IllegalArgumentException: 指定的主资源集 [G:\apache-tomcat-10.0.21-windows-x64\apache-tomcat-10.0.21\webapps\java.html] 无效at org.apache.catalina.webresources.StandardRoot.createMainResourceSet(StandardRoot.java:762)at org.apache.catalina.webresources.StandardRoot.startInternal(StandardRoot.java:719)at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)... 30 more
06-Apr-2023 22:27:27.968 信息 [main] org.apache.coyote.AbstractProtocol.pause 暂停ProtocolHandler["http-nio-8080"]
06-Apr-2023 22:27:27.968 信息 [main] org.apache.catalina.core.StandardService.stopInternal 正在停止服务[Catalina]
06-Apr-2023 22:27:27.968 信息 [main] org.apache.coyote.AbstractProtocol.destroy 正在摧毁协议处理器 ["http-nio-8080"]
已与服务器断开连接

(1)找原因:看最后一个Caused by:后面的内容。

Caused by: java.lang.IllegalArgumentException: 指定的主资源集 [G:\apache-tomcat-10.0.21-windows-x64\apache-tomcat-10.0.21\webapps\java.html] 无效

 这是最后一个Caused by的内容:java.html无效。

去tomcat下的conf目录下的server.xml文件:直接翻到最下面-看到 "/java.xml".

(2)解决:我是直接删除"java.html",然后可运行。 

二、Tomcat工件部署出错。

(1)错误原因1:javax.servlet.ServletContextListener。

Caused by: java.lang.ClassNotFoundException: javax.servlet.ServletContextListener。

1、jar文件没有同步发布到自己项目的lib目录中,也即是你编译之后生成的文件内,没有lib目录(没有jar包)

(1)解决方法一:换一个版本的Tomcat。

本来是10.0.21版本的tomcat服务器,但是一直工件错误,然后找了很久都没找到解决方法,但是 javax.servlet.ServletContextListener类是可以找到的。然后我换了个版本的服务器,出奇的竟然可以正常部署了。

(2) 解决方法二:在pom.xml文件中添加<packaging>标签

<packaging>war</packaging>

(3) 解决方法三:Put into Output Root

这是由于pom.xml中下载的jar包未被部署。我们先ctrl+shift+alt+s打开Project Structure窗口,选择Artifacts,选择要打包部署的项目,在Output Layout –> Web-INF查看是否有lib目录,如果右边Available Elements窗口还显示有jar包,说明这些jar包未添加,则应右击选择Put into Output Root就可以了。

注意:这些方法,说的是我的经验,不一定就可以解决或正确,因为有时候做了某个操作莫名奇妙就可以运行了,然后改回来之后,还是可以运行,这个操作就存在疑问????了,因为很难验证或者验证不了。

(2)出错原因2:NotWritablePropertyException: Invalid property 'jdbcTemplate' of bean class [dao.impl.UserDaoImpl]。

	Caused by: org.springframework.beans.NotWritablePropertyException: Invalid property 'jdbcTemplate' of bean class [dao.impl.UserDaoImpl]: Bean property 'jdbcTemplate' is not writable or has an invalid setter method. Does the parameter type of the setter match the return type of the getter?at org.springframework.beans.BeanWrapperImpl.createNotWritablePropertyException(BeanWrapperImpl.java:243)at org.springframework.beans.AbstractNestablePropertyAccessor.processLocalProperty(AbstractNestablePropertyAccessor.java:426)at org.springframework.beans.AbstractNestablePropertyAccessor.setPropertyValue(AbstractNestablePropertyAccessor.java:278)at org.springframework.beans.AbstractNestablePropertyAccessor.setPropertyValue(AbstractNestablePropertyAccessor.java:266)at org.springframework.beans.AbstractPropertyAccessor.setPropertyValues(AbstractPropertyAccessor.java:97)at org.springframework.beans.AbstractPropertyAccessor.setPropertyValues(AbstractPropertyAccessor.java:77)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1638)... 69 more
13-Apr-2023 12:37:32.663 信息 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.ApplicationContext.log Closing Spring root WebApplicationContext
13-Apr-2023 12:37:37.082 信息 [Catalina-utility-1] org.apache.catalina.core.ApplicationContext.log ContextListener: contextInitialized()
13-Apr-2023 12:37:37.082 信息 [Catalina-utility-1] org.apache.catalina.core.ApplicationContext.log SessionListener: contextInitialized()
13-Apr-2023 12:37:37.085 信息 [Catalina-utility-1] org.apache.catalina.core.ApplicationContext.log ContextListener: attributeAdded('StockTicker', 'async.Stockticker@74aed74b')

(1)错误:类没有设置setter方法。

Invalid property 'jdbcTemplate' of bean class [dao.impl.UserDaoImpl]: Bean property 'jdbcTemplate' is not writable or has an invalid setter method. 

(2)解决方法:在pom.xml文件中<packaging>war</packaging>。

我的问题是我在该类中已经加了setter方法,但是它一直出现这个问题。

然后我就在pom.xml文件中添加了以下代码。

<packaging>war</packaging>

三、Tomcat服务器启动时的日志是乱码。

(1)解决方法1-环境变量。

在系统的环境变量中添加一个变量,名为: JAVA_TOOL_OPTIONS, 值为:-Dfile.encoding=UTF-8\n这样就能让server下的中文也变成UTF-8编码。

(2)解决方法2-tomcat配置VM-options。

在tomcat配置VM- options: 填入:-Dfile.encoding=UTF-8。(这个设置后还是乱码的,所以可以不设置这里,直接在IDEA中设置)。

(3)解决方法3-IEDA配置VM-options。

DEA help->edit custom VM options中保留-Dfile.encoding=UTF-8。

 (4)解决乱码后的显示。 


http://chatgpt.dhexx.cn/article/O1D3Eax2.shtml

相关文章

tomcat启动失败的常见原因

根据不同情况,笔者碰到过的有以下几种情况: 1. 运行tomcat的启动文件startup.bat,弹出黑窗口,直接闪退。 这种情况一般都是没有配置JAVA_HOME导致的,配置jdk如果没有使用JAVA_HOME的方式配置环境变量,就会出这种问题 2. 启动后,停留一段时间,打印一些日志,然后窗口…

【tomcat】tomcat启动失败的种种(持续更新)

初始化配置问题 易感人群&#xff1a;部分版本&#xff08;注意不是全部&#xff09;版本在安装初期会发生的问题 解决方法&#xff1a; 将Tomcat的Server Location配置改为第二个即可 但此时问题来了&#xff0c;为什么选项会是灰色不可更改的呢&#xff1f; 答&#xff1…

二叉树的先序遍历(源代码)

1.先序遍历 要点&#xff1a; ⑴ 访问根结点&#xff1b; ⑵ 遍历左子树&#xff1b; ⑶ 遍历右子树。 例子&#xff1a;如下图,先序遍历方式结果输出为&#xff1a;ABDECF 代码实现&#xff08;递归版&#xff09;&#xff1a; void preOrder1(BinTree *root) //递…

关于完全二叉树先序遍历,中序遍历,后续遍历

【本文都先遍历左子树】 先序遍历 先序遍历是先双亲&#xff0c;再左子树到底&#xff0c;后兄弟&#xff0c;遇到什么就输出什么&#xff0c;在二叉树里面&#xff0c;从根节点开始输出一直输出到左子树的左叶子结点【*nextptrnull】&#xff0c;再做递归返回到当前节点的双亲…

二叉树先序遍历非递归遍历算法

/*二叉树的先序遍历非递归算法目标遍历的二叉树:1/ \2 4/ \3 5 待输出结果为1,2,3,5,41.首先得用上面定义的结构体把这颗树表示出来2.表示出这颗树后在调用二叉树的先序遍历非递归算法 */#include <iostream> using namespace std; # define maxSize 10 //树结点的结…

二叉树的先序遍历(C++)

参考&#xff1a;二叉树的先序遍历 先序遍历&#xff0c;简而言之就是&#xff1a;根、左、右。 按照先序遍历的访问顺序&#xff0c;肯定会把最左边那条路全部遍历完——终止条件是访问到了最左下角的空节点&#xff0c;再往回走。 //T是指向二叉树顶端节点的结构体指针&…

二叉树先序遍历算法--C语言

第一次在CSDN上写博客&#xff0c;今天开启自己的编程之路。以前总觉得上课嘛&#xff0c;把老师讲的东西学会&#xff0c;考试能过就好了。但是后来发现&#xff0c;自己被这种想法坑惨了。知识点当时是学会了&#xff0c;但是随着考试的结束&#xff0c;学到的知识也一并还给…

依据二叉树的先序遍历和中序遍历求其后序遍历

【问题描述】 假定一棵二叉树的每个结点都用一个大写字母描述。 给定这棵二叉树的先序遍历和中序遍历&#xff0c;求其后序遍历。 下图是依据下文算法代码绘制的示意图。 【输入格式】 输入包含多组测试数据。 每组数据占两行&#xff0c;每行包含一个大写字母构成的字符串&am…

已知二叉树的先序遍历和中序遍历画出该二叉树

对一棵二叉树进行遍历&#xff0c;我们可以采取3中顺序进行遍历&#xff0c;分别是前序遍历、中序遍历和后序遍历。 这三种方式是以访问父节点的顺序来进行命名的。 假设父节点是N&#xff0c;左节点是L&#xff0c;右节点是R&#xff0c;那么对应的访问遍历顺序如下&#xf…

二叉树先序遍历的非递归算法

在前面一文&#xff0c;说过二叉树的递归遍历算法&#xff08;二叉树先根&#xff08;先序&#xff09;遍历的改进&#xff09;&#xff0c;此文主要讲二叉树的非递归算法&#xff0c;采用栈结构 总结先根遍历得到的非递归算法思想如下&#xff1a; 1&#xff09;入栈&#x…

二叉树的先序递归遍历算法

怎样遍历一棵二叉树呢&#xff1f;把它看成三个部分&#xff1a; 根结点&#xff0c;左子树&#xff0c;右子树&#xff0c;所以要遍历一棵二叉树&#xff0c;就要分别遍历这三个部分 访问完毕左子树 访问完毕右子树 序列&#xff1a; 如何实现算法&#xff1f;首先考虑存储结构…

关于二叉树先序遍历和后序遍历为什么不能唯一确定一个二叉树分析

文章目录 二叉树唯一确定先序和中序递归构建二叉树的过程先序和后序递归构建二叉树的过程先序和后序递归构建二叉树的代码如果二叉树不唯一&#xff0c;怎么处理完整代码分析自己的问题 二叉树唯一确定 对于一个二叉树&#xff0c;并不是说给出了先序和后序就是无法唯一确定的。…

二叉树的递归遍历(先序输入)

今天来看看二叉树的递归遍历&#xff0c;我们要实现二叉树的先序&#xff0c;中序&#xff0c;后续遍历 这里我们采用的是先序输入 下面是完整代码 #include <stdio.h> #include <stdlib.h> struct node {char data;node *Lchild;node *Rchild; }tree; node *cr…

根据二叉树先序遍历和中序遍历构建二叉树

前方有一个人在等着你&#xff0c;你只管勇敢的向前走 采用递归分治的思想&#xff0c;将一个大问题划分成子问题&#xff0c; 对于本题&#xff0c;根据二叉树先序遍历和中序遍历构建二叉树&#xff0c;思路&#xff1a; 我们可以求得根节点左子树的先序和中序序列&#xff0…

二叉树前序、中序、后序遍历非递归写法的透彻解析

前言 在前两篇文章二叉树和二叉搜索树中已经涉及到了二叉树的三种遍历。递归写法&#xff0c;只要理解思想&#xff0c;几行代码。可是非递归写法却很不容易。这里特地总结下&#xff0c;透彻解析它们的非递归写法。其中&#xff0c;中序遍历的非递归写法最简单&#xff0c;后…

二叉树的后序遍历

二叉树文章系列&#xff1a; 二叉树的前序遍历二叉树的中序遍历二叉树的后序遍历二叉树的层序遍历二叉树的前序、中序、后序、层序遍历【解法完整版】 本文目录 一、解题思路&#xff1a;递归二、解题思路&#xff1a;迭代&#xff08;方法1&#xff09;三、解题思路&#xff…

C语言完整代码实现:二叉树的先序遍历、中序遍历、后序遍历

一、先序遍历原理 先序遍历就是&#xff1a;根、左、右&#xff0c;也就是先遍历根结点再遍历左结点最后再遍历右结点&#xff0c;注意&#xff1a;如果遍历到的结点不是叶子结点的话需要对该结点进行拆分&#xff0c;比如这棵二叉树&#xff1a; 先遍历A&#xff0c;然后是B&a…

数据结构——二叉树的先序遍历

二叉树的遍历分为 先序遍历&#xff0c;中序遍历&#xff0c;后序遍历&#xff0c;层次遍历 四种遍历。 这节要分享的是先序遍历 如图所示&#xff0c;这是一个普通的二叉树。他的先序遍历是&#xff1a;A B D E H C F G I J 为什么呢&#xff1f; 先序遍历的遍历规则是&am…

二叉树三种遍历顺序

三.二叉树的三种遍历方式 1.先序遍历&#xff1a;按照根节点->左子树->右子树的顺序访问二叉树 先序遍历&#xff1a;&#xff08;1&#xff09;访问根节点&#xff1b;&#xff08;2&#xff09;采用先序递归遍历左子树&#xff1b;&#xff08;3&#xff09;采用先序…

二叉树(Binary Tree):先序遍历、中序遍历、后序遍历和层次遍历

二叉树&#xff08;Binary Tree&#xff09;&#xff1a;先序遍历、中序遍历、后序遍历和层次遍历 树 Tree二叉树 Binary Tree先序遍历 Preorder Traversal中序遍历 Inoreder Traversal后序遍历 Postorder Traversal层次遍历 Level Traversal 树 Tree 根 Root&#xff1a;树顶部…