`
JavaVM
  • 浏览: 7111 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

链接已经被关闭的问题,我都快疯了。

阅读更多
公司一个项目使用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上发帖。希望,多谢大家了。
分享到:
评论
2 楼 dengyin2000 2007-03-05  
是不是  mysql connection url后面要加上  autoConnect=true
1 楼 dada 2007-03-05  
没有代码很难猜测,换jetty或者tomcat试试看连接是否关闭。建议把resin更新到最新版本,3.1.1更新了resin的相关错误。

如果还无法解决,请贴代码。

相关推荐

    快速关闭所有IE窗口

    标题“快速关闭所有IE窗口”所涉及的知识点主要与计算机操作和系统管理相关,特别是针对Internet Explorer(IE)浏览器的问题处理。在描述中提到的情况,用户可能遇到了恶意网站或者受到某些恶意程序的影响,导致IE...

    疯狂喷气机电脑版 疯狂喷气机pc版 v1 3 6 pc电脑版

    "unrar.dll"则是一个用于解压RAR格式文件的动态链接库,可能表明游戏安装包内包含了RAR压缩文件,需要这个组件来正确解压和安装游戏。"疯狂喷气机电脑版(疯狂喷气机pc版)v1.3.6 pc电脑版.exe"是游戏的可执行文件,...

    疯狂桌面v2.2 桌面切换 老板键

    传统的操作系统一般只有一个桌面,所有窗口都在这个单一平面上堆叠,导致工作和娱乐应用混杂,降低了工作效率。而这款软件则突破了这一限制,用户可以根据自己的需要创建多个桌面,每个桌面可以设定不同的用途,例如...

    疯狂内核之——虚拟文件系统

    在Linux操作系统中,所有设备都被抽象成文件的形式,无论是磁盘、串口还是键盘鼠标,都被视为一个文件。这种将不同类型的硬件资源统一抽象成文件的方式,形成了Linux中的“一切皆文件”的哲学思想。为了支持这种通用...

    【PHP】朋友圈疯传营销吸粉源码|微信测试游戏程序趣味互动传播分享微测

    是否开启底部广告,1为开启,0为关闭,默认是关闭着此广告位。 $openad = 0; 当值为1时,表示开启底部广告位,广告位的形式为图片+链接。 修改广告位上面的图片和点击链接方式是: 打开js目录下bottomad.js文件,将...

    疯狂java实战演义源码-AndroidTips:https://github.com/cokuscz/AndroidTips.git

    疯狂java实战演义源码 AndroidTips A collections ...答:在设置输入法选项中,关闭物理键盘即可。 3.genymotion如何安装谷歌服务? 答: 二.Android Studio 1.Andorid Studio中有哪些好用的插件? &gt;答: 1&gt;.:

    不使用maven的方式链接mysql数据库压缩包

    在Java开发中,链接MySQL数据库通常依赖于特定的驱动程序,即JDBC(Java Database Connectivity)驱动。在标题和描述中提到的“不使用maven的方式链接mysql数据库”,指的是不通过Maven这样的构建管理系统,而是手动...

    C# winform 运行前释放令一个文件(或DLL)

    在C# WinForm应用开发中,有时为了保护代码或者实现某些特定功能,我们可能需要在程序运行时动态加载外部文件,比如DLL(动态链接库)文件。标题中的“C# WinForm 运行前释放令一个文件(或DLL)”指的就是这种技术。...

    strange-therapy:奇怪的疗法

    你(我还是)是一名大学生,那已经快到一个学期末了。 您只是另一个疯狂的孩子,一次又一次地考试-为暑假做好了准备... 信用 我是此游戏中代码和美术的唯一创作者-以下内容除外 代码 (MIT许可证) (MIT许可) ...

    计算机软件-商业源码-疯狂VC技巧集.zip

    1. **优化编译器设置**:了解如何通过调整编译器选项来优化代码性能,如开启或关闭特定的编译器优化,以及选择合适的运行时库(多线程DLL、静态链接等)。 2. **内存管理**:理解C++中的动态内存分配和释放,避免...

    c++ xml读取操作库

    例如,TinyXML库可以被编译成DLL,程序中通过`#import`或`LoadLibrary/GetProcAddress`等方式调用库函数。 三、ReadXml工程源码解析 "ReadXml"工程源码可能包含了使用某个XML库进行XML读取的示例。通常,源码会包含...

    libxls.lib, win32

    `libxls.def` 是一个导入库定义文件,它包含了库中公开函数的声明,这些函数可以被其他程序调用。`libxls.dll` 是动态链接库文件,运行时提供服务,当程序需要执行libxls的功能时,会加载这个DLL。而 `libxls.lib` ...

    VS2010+ffmpeg2.0 调试通过 运行直接播放视频代码

    编译过程通常包括配置、生成解决方案、编译源码和链接库等步骤,确保所有必要的组件如libavcodec、libavformat、libavutil等都被正确编译和链接。 在编译FFmpeg时,可能会遇到一些常见的问题,比如找不到某些依赖库...

    网络安全的误区.docx

    现在有许多人都认为自己的电脑,在边界安装了防火墙、在桌面上安装了防病毒和防间谍软件工具、使用加密技术发送和保存数据,疯狂补丁打漏洞,就以为万无一失了,可事实真的是这样吗让带你了解一下常见的网络误区吧。...

    OpenVFD:6位数字IV-11 VFD管时钟-电路方案

    当时,他们被链接在一起,组成了大型计算器的显示器。许多这些管子都是生产出来的,即使在今天也很容易获得。 OpenVFD背后的哲学是什么? 我想用最漂亮的颜色重新创建VFD时钟,看看多彩的时间。一个IV-11时钟与不...

    网址点击器.rar

    假如有10个网址,动作次数10次,那么每个网址会被点击1次(计算公式:10次动作/10个网址) 注, * 参考时间间隔:要单击的坐标数量 * 单个页面加载的时间。单位:秒 * 用户自定义IP文件名 myip.txt * config.ini...

    DynamicHistory-crx插件

    语言:English ...您可以使用它来做疯狂的事情,例如将所有历史记录条目都变成“ Rick Roll”链接。 重要信息:启用Chrome的历史记录同步后,DynamicHistory无法正常运行。 安装DynamicHistory后,将弹

Global site tag (gtag.js) - Google Analytics