公司一个项目使用Webwork+Spring+iBATIS 这个结构来实现的。应用服务器是resin3.0.19 而是数据库是MYSQL5.0。项目在开发过程中一直很正常没有什么大问题,但进入集成测试后发现经常抛出异常。
500 Servlet Exception
java.lang.IllegalStateException: connection is closed
at com.caucho.sql.UserConnection.getMConn(UserConnection.java:812)
at com.caucho.sql.UserConnection.getConnection(UserConnection.java:87)
at com.caucho.sql.UserConnection.prepareStatement(UserConnection.java:195)
at sun.reflect.GeneratedMethodAccessor109.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy$TransactionAwareInvocationHandler.invoke(TransactionAwareDataSourceProxy.java:168)
at $Proxy27.prepareStatement(Unknown Source)
at com.ibatis.sqlmap.engine.execution.SqlExecutor.executeQuery(SqlExecutor.java:172)
at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.sqlExecuteQuery(GeneralStatement.java:205)
at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryWithCallback(GeneralStatement.java:173)
at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryForList(GeneralStatement.java:123)
at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForList(SqlMapExecutorDelegate.java:614)
at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForList(SqlMapSessionImpl.java:126)
at com.ibatis.sqlmap.engine.impl.SqlMapClientImpl.queryForList(SqlMapClientImpl.java:104)
at com.ibatis.sqlmap.engine.mapping.statement.PaginatedDataList.getList(PaginatedDataList.java:127)
at com.ibatis.sqlmap.engine.mapping.statement.PaginatedDataList.pageTo(PaginatedDataList.java:87)
at com.ibatis.sqlmap.engine.mapping.statement.PaginatedDataList.<init>(PaginatedDataList.java:46)
at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForPaginatedList(SqlMapExecutorDelegate.java:671)
at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForPaginatedList(SqlMapSessionImpl.java:134)
at org.springframework.orm.ibatis.SqlMapClientTemplate$6.doInSqlMapClient(SqlMapClientTemplate.java:273)
at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:168)
at org.springframework.orm.ibatis.SqlMapClientTemplate.queryForPaginatedList(SqlMapClientTemplate.java:271)
at net.pingsoft.pledu.basedao.BaseSqlMapDAO.search(BaseSqlMapDAO.java:92)
at net.pingsoft.pledu.dao.ibatis.SysSchoolInfoSqlMapDAO.search(SysSchoolInfoSqlMapDAO.java:28)
at net.pingsoft.pledu.domain.logic.impl.SchoolServiceImpl.searchSchoolByFilter(SchoolServiceImpl.java:207)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:287)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:165)
at $Proxy1.searchSchoolByFilter(Unknown Source)
at net.pingsoft.pledu.webwork.action.manage.school.ListSchoolInfoAction.searchByName(ListSchoolInfoAction.java:65)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at com.opensymphony.xwork.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:365)
at com.opensymphony.xwork.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:217)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:191)
at net.pingsoft.pledu.webwork.Interceptor.UserRightInterceptor.intercept(UserRightInterceptor.java:53)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.AroundInterceptor.intercept(AroundInterceptor.java:31)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:100)
at com.opensymphony.xwork.DefaultActionInvocation.invoke(DefaultActionInvocation.java:189)
at com.opensymphony.xwork.DefaultActionProxy.execute(DefaultActionProxy.java:113)
at com.opensymphony.webwork.dispatcher.DispatcherUtils.serviceAction(DispatcherUtils.java:233)
at com.opensymphony.webwork.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:198)
at com.caucho.server.dispatch.FilterFilterChain.doFilter(FilterFilterChain.java:70)
at com.opensymphony.module.sitemesh.filter.PageFilter.doFilter(PageFilter.java:56)
at com.caucho.server.dispatch.FilterFilterChain.doFilter(FilterFilterChain.java:70)
at com.opensymphony.webwork.dispatcher.ActionContextCleanUp.doFilter(ActionContextCleanUp.java:78)
at com.caucho.server.dispatch.FilterFilterChain.doFilter(FilterFilterChain.java:70)
at net.pingsoft.pledu.servlet.GZIPFilter.doFilter(GZIPFilter.java:63)
at com.caucho.server.dispatch.FilterFilterChain.doFilter(FilterFilterChain.java:70)
at com.caucho.server.webapp.WebAppFilterChain.doFilter(WebAppFilterChain.java:178)
at com.caucho.server.dispatch.ServletInvocation.service(ServletInvocation.java:229)
at com.caucho.server.http.HttpRequest.handleRequest(HttpRequest.java:268)
at com.caucho.server.port.TcpConnection.run(TcpConnection.java:389)
at com.caucho.util.ThreadPool.runTasks(ThreadPool.java:507)
at com.caucho.util.ThreadPool.run(ThreadPool.java:433)
at java.lang.Thread.run(Thread.java:595)
--------------------------------------------------------------------------------
Resin-3.0.19 (built Mon, 15 May 2006 04:50:47 PDT)
本来想将源代码贴出来,但是公司封闭源代码,要申请才行(恶心)。关于这个问题我查过很多,有些说是数据库连接池里的连接失效了,有些说没有关闭连接。因为我们使用的是iBATIS模板方法,它应该自己在用完连接就关闭的,而不需要自己关闭。所以我把注意力放在了连接池。但是不管我怎么找资料还是配置总是不行。
第一次在javaeye上发帖。希望,多谢大家了。
分享到:
相关推荐
标题“快速关闭所有IE窗口”所涉及的知识点主要与计算机操作和系统管理相关,特别是针对Internet Explorer(IE)浏览器的问题处理。在描述中提到的情况,用户可能遇到了恶意网站或者受到某些恶意程序的影响,导致IE...
"unrar.dll"则是一个用于解压RAR格式文件的动态链接库,可能表明游戏安装包内包含了RAR压缩文件,需要这个组件来正确解压和安装游戏。"疯狂喷气机电脑版(疯狂喷气机pc版)v1.3.6 pc电脑版.exe"是游戏的可执行文件,...
传统的操作系统一般只有一个桌面,所有窗口都在这个单一平面上堆叠,导致工作和娱乐应用混杂,降低了工作效率。而这款软件则突破了这一限制,用户可以根据自己的需要创建多个桌面,每个桌面可以设定不同的用途,例如...
在Linux操作系统中,所有设备都被抽象成文件的形式,无论是磁盘、串口还是键盘鼠标,都被视为一个文件。这种将不同类型的硬件资源统一抽象成文件的方式,形成了Linux中的“一切皆文件”的哲学思想。为了支持这种通用...
是否开启底部广告,1为开启,0为关闭,默认是关闭着此广告位。 $openad = 0; 当值为1时,表示开启底部广告位,广告位的形式为图片+链接。 修改广告位上面的图片和点击链接方式是: 打开js目录下bottomad.js文件,将...
疯狂java实战演义源码 AndroidTips A collections ...答:在设置输入法选项中,关闭物理键盘即可。 3.genymotion如何安装谷歌服务? 答: 二.Android Studio 1.Andorid Studio中有哪些好用的插件? >答: 1>.:
在Java开发中,链接MySQL数据库通常依赖于特定的驱动程序,即JDBC(Java Database Connectivity)驱动。在标题和描述中提到的“不使用maven的方式链接mysql数据库”,指的是不通过Maven这样的构建管理系统,而是手动...
在C# WinForm应用开发中,有时为了保护代码或者实现某些特定功能,我们可能需要在程序运行时动态加载外部文件,比如DLL(动态链接库)文件。标题中的“C# WinForm 运行前释放令一个文件(或DLL)”指的就是这种技术。...
你(我还是)是一名大学生,那已经快到一个学期末了。 您只是另一个疯狂的孩子,一次又一次地考试-为暑假做好了准备... 信用 我是此游戏中代码和美术的唯一创作者-以下内容除外 代码 (MIT许可证) (MIT许可) ...
1. **优化编译器设置**:了解如何通过调整编译器选项来优化代码性能,如开启或关闭特定的编译器优化,以及选择合适的运行时库(多线程DLL、静态链接等)。 2. **内存管理**:理解C++中的动态内存分配和释放,避免...
例如,TinyXML库可以被编译成DLL,程序中通过`#import`或`LoadLibrary/GetProcAddress`等方式调用库函数。 三、ReadXml工程源码解析 "ReadXml"工程源码可能包含了使用某个XML库进行XML读取的示例。通常,源码会包含...
`libxls.def` 是一个导入库定义文件,它包含了库中公开函数的声明,这些函数可以被其他程序调用。`libxls.dll` 是动态链接库文件,运行时提供服务,当程序需要执行libxls的功能时,会加载这个DLL。而 `libxls.lib` ...
编译过程通常包括配置、生成解决方案、编译源码和链接库等步骤,确保所有必要的组件如libavcodec、libavformat、libavutil等都被正确编译和链接。 在编译FFmpeg时,可能会遇到一些常见的问题,比如找不到某些依赖库...
现在有许多人都认为自己的电脑,在边界安装了防火墙、在桌面上安装了防病毒和防间谍软件工具、使用加密技术发送和保存数据,疯狂补丁打漏洞,就以为万无一失了,可事实真的是这样吗让带你了解一下常见的网络误区吧。...
当时,他们被链接在一起,组成了大型计算器的显示器。许多这些管子都是生产出来的,即使在今天也很容易获得。 OpenVFD背后的哲学是什么? 我想用最漂亮的颜色重新创建VFD时钟,看看多彩的时间。一个IV-11时钟与不...
假如有10个网址,动作次数10次,那么每个网址会被点击1次(计算公式:10次动作/10个网址) 注, * 参考时间间隔:要单击的坐标数量 * 单个页面加载的时间。单位:秒 * 用户自定义IP文件名 myip.txt * config.ini...
语言:English ...您可以使用它来做疯狂的事情,例如将所有历史记录条目都变成“ Rick Roll”链接。 重要信息:启用Chrome的历史记录同步后,DynamicHistory无法正常运行。 安装DynamicHistory后,将弹