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

文章详细列举了Tomcat服务器在启动失败、工件部署出错以及日志乱码等三个方面遇到的问题,并提供了相应的排查和解决步骤。对于启动失败,问题出在主资源集无效,删除引起问题的文件即可;工件部署错误可能涉及ServletContextListener的类找不到或JdbcTemplate属性设置问题,解决方案包括更换Tomcat版本、修改pom.xml配置;日志乱码则可通过设置环境变量或IDEA的VM选项来解决编码问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、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 more
	Caused 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 more
	Caused 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 more
	Caused 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 more
	Caused 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)解决乱码后的显示。 

### 解决 Tomcat 10.1 启动失败的方法 对于 Tomcat 10.1 启动失败的情况,可以从以下几个方面排查并解决问题。 #### 检查 `server.xml` 文件中的 XML 语法 确保 `conf/server.xml` 文件中不存在任何 XML 语法错误。XML 结构不正确可能会导致服务器无法正常解析配置文件从而引发启动失败[^1]。 #### 清理工作目录 尝试清理 Tomcat 的工作目录 (`work/Catalina`) 和临时文件夹 (`temp`)。这些位置存储着编译后的 JSP 页面和其他运行时数据;残留的数据可能导致冲突或异常行为。删除其中的内容可以排除因旧缓存引起的潜在问题。 #### 处理 API 包命名空间变更 如果应用程序依赖于 Java EE 技术栈,则需要注意自 Tomcat 10 开始已迁移到 Jakarta EE 平台,这意味着所有的接口包名称由原来的 `javax.*` 变更为 `jakarta.*` 。因此建议检查应用代码及其库是否已经更新至支持新标准版本,并考虑降级到更早版本如 Tomcat 9 来规避此兼容性障碍[^2]。 #### 添加 Maven 依赖项 当使用 Eclipse 或者其他 IDE 进行开发时,确认项目的构建工具(比如 Maven)所管理的外部 jar 库已被正确打包进 Web 应用程序内。缺少必要的第三方类库同样会造成容器初始化阶段抛出异常终止进程执行。可以通过调整 IDE 设置来保证所有必需组件随同 WAR 文件一同部署给 Tomcat 实例[^3]。 #### 验证 JAVA_HOME 环境变量设置 最后但并非最不重要的是要验证系统的 JAVA_HOME 环境变量指向了一个有效的 JDK 安装路径。因为 Tomcat 是基于 JVM 构建的应用服务器,它需要能够找到合适的 Java Runtime Environment (JRE) 才能顺利运作。如果没有正确设定该参数则很可能造成找不到主类或其他类似的致命错误消息显示出来[^4]。 ```bash echo %JAVA_HOME% ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值