博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决莫名其妙出现connection closed的错误
阅读量:6149 次
发布时间:2019-06-21

本文共 1065 字,大约阅读时间需要 3 分钟。

最近发现使用了springMVC的新项目偶尔出现connection closed,同事反映当访问同一个controller时经常出现类似错误

上回发现在使用

<context:component-scan base-package="com.controller" />

对@controller注解扫描生成的controller,若是没有加@Scope("prototype")的话,生成出来的controller就是单例的。见

虽然发现这个问题但是由于connection closed的错误现象很难重现,因此上回放弃了。

今天晚上我在测试中无意中又出现了这样的错误,我对controller加了@Scope("prototype"),还是出现一样的错误。

我用下面的语句打印本类的地址,发现每次打印出来的地址都不一样,证明每次请求都重新创建了controller

System.out.println("reserve:"+this.getClass().getName()

+"@"+Integer.toHexString(this.hashCode()));

 

这时我注意到service是用@Autowired,于是我把service的地址也打印出来,发现service 的地址,每次访问都是一样的。也就是说虽然controller是多例了,但是里面的service是单例的,因此每次把新建的connection赋予service之后,请求结束就关闭连接这种方式存在问题。

我的每一个service的connection是通过setConn访问给传进去的,其它数据库方法都使用这个service的connection.

在两个请求同时请求到同一个service时,若是先开始创建connection一个service执行比较慢,而另一个后开始的service也申请了新的一个connection,由于service是单例的,就会把第一个connection给覆盖掉了。若是第二个service先完成就关闭连接,那么第一个service就会出现“connection closed”错误,从而出现一个未关闭的connection(第一个service申请的connection)。

解决办法

1.在controller和service上都增加@Scope("prototype"),这样controller和service都是多例。

2.service不采取setconn方法,每个方法都从参数获取connection.

转载地址:http://fpgya.baihongyu.com/

你可能感兴趣的文章
python 解析 XML文件
查看>>
MySQL 文件导入出错
查看>>
java相关
查看>>
由一个异常开始思考springmvc参数解析
查看>>
向上扩展型SSD 将可满足向外扩展需求
查看>>
浏览器缓存
查看>>
类的拷贝管理
查看>>
codeforces - 732D Exams 【二分 + 贪心】
查看>>
CF446D DZY Loves Games
查看>>
systemd 之 systemctl
查看>>
Scut游戏服务器免费开源框架--快速开发(2)
查看>>
JDBC规范(转)
查看>>
centos7下安装nginx
查看>>
zabbix 监控docker
查看>>
传播行为
查看>>
CCF NOI1140 高精度乘法
查看>>
如何制定绩效计划
查看>>
安装Microsoft Dynamics CRM 2011时出现“Microsoft.Crm.Setup.Common.Analyzer+CollectAction 操作失败”的解决办法...
查看>>
js异步编程终级解决方案 async/await
查看>>
Android Studio 更新
查看>>