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

目录

一、Tomcat服务器启动失败。

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

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

二、Tomcat工件部署出错。

(1)出错原因:

(2)解决:换一个版本的Tomcat。

三、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".

13.Tomcat服务器启动失败的总结_第1张图片

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

13.Tomcat服务器启动失败的总结_第2张图片

二、Tomcat工件部署出错。

13.Tomcat服务器启动失败的总结_第3张图片

(1)出错原因:

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

(2)解决:换一个版本的Tomcat。

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

13.Tomcat服务器启动失败的总结_第4张图片

三、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中设置)。

13.Tomcat服务器启动失败的总结_第5张图片

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

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

13.Tomcat服务器启动失败的总结_第6张图片13.Tomcat服务器启动失败的总结_第7张图片

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

 

 

你可能感兴趣的:(核心日记-java道路,tomcat,java,servlet)