记一次花费一天时间debug的过程 ╰半橙微兮° 2022-08-19 02:22 135阅读 0赞 原本是在项目中解决一个问题,结果出了另一个问题,结果原来的问题没解决,反而被新的问题占据了一天时间,开发中这种情况应该也挺常见的吧,只是debug的过程感觉不太好,不过这也算是一种成长吧。 bug情况记录:[社区问题问答][Link 1] ## 问题描述: ## tomcat运行突然卡住。 ## web.xml : ## <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- 编码过滤 --> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- Spring listener --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- Spring --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/applicationContext.xml</param-value> </context-param> <!-- SpringMVC --> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> </web-app> ## tomcat运行截图: ## ![tomcat运行截图][tomcat] ## debug过程: ## 1. 初步以为是新加的某些配置出问题,然后把那些配置全删了,结果还是不行; 2. 使用经常使用的招数:重启+换个新的tomcat,结果发现是web.xml里的配置项 ContextLoaderListener 导致不能运行; 3. 上社区发布的问题,有个思路比较好:查看日志,原本的tomcat的日志太少了,只有一句:`org.apache.catalina.core.StandardServer.await StandardServer.await: Invalid command '' received` 。 4. 但随之想到可以手动加log,于是引入了 log4j,在运行时打出所有的日志,诶结果发现一个Exception:`ava.lang.NoClassDefFoundError: org/springframework/jdbc/datasource/TransactionAwareDataSourceProxy`,查了一下是因为少了 spring-jdbc.jar 这个jar包,加上,问题解决! [Link 1]: http://segmentfault.com/q/1010000004237076 [tomcat]: /images/20220731/0239e3bfd10b4a7fba1764e03cf6e1ec.png
还没有评论,来说两句吧...