本文主要是介绍记一次花费一天时间debug的过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
原本是在项目中解决一个问题,结果出了另一个问题,结果原来的问题没解决,反而被新的问题占据了一天时间,开发中这种情况应该也挺常见的吧,只是debug的过程感觉不太好,不过这也算是一种成长吧。
bug情况记录:社区问题问答
问题描述:
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/javaeehttp://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运行截图:
debug过程:
- 初步以为是新加的某些配置出问题,然后把那些配置全删了,结果还是不行;
- 使用经常使用的招数:重启+换个新的tomcat,结果发现是web.xml里的配置项 ContextLoaderListener 导致不能运行;
- 上社区发布的问题,有个思路比较好:查看日志,原本的tomcat的日志太少了,只有一句:
org.apache.catalina.core.StandardServer.await StandardServer.await: Invalid command '' received
。 - 但随之想到可以手动加log,于是引入了 log4j,在运行时打出所有的日志,诶结果发现一个Exception:
ava.lang.NoClassDefFoundError: org/springframework/jdbc/datasource/TransactionAwareDataSourceProxy
,查了一下是因为少了 spring-jdbc.jar 这个jar包,加上,问题解决!
这篇关于记一次花费一天时间debug的过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!