目录
一、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 more06-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文件中添加标签
war
(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" />(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文件中war。
我的问题是我在该类中已经加了setter方法,但是它一直出现这个问题。
然后我就在pom.xml文件中添加了以下代码。
war
三、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)解决乱码后的显示。