com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
来源:互联网 发布:tensor flow 知乎 编辑:程序博客网 时间:2024/06/03 23:47
eclipse配置使用MySQL,项目启动后,加载页面后台报错:
com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed. 解决
ERROR - No operations allowed after connection closed.
参考:http://www.cnblogs.com/interdrp/p/4177648.html
<---- 引用
分析,出现这种异常的原因是:
Mysql 服务器默认的“wait_timeout”是8小时,也就是说一个connection空闲超过8个小时,Mysql将自动断开该connection。 这就是问题的所在,在C3P0 pools中的connections如果空闲超过8小时,mysql将其断开,而C3P0并不知道该connection已经失效,如果这时有 Client请求connection,C3P0将该失效的Connection提供给Client,将会造成上面的异常。
a)解决的方法有3种:
增加wait_timeout的时间。
减少Connection pools中connection的lifetime。
测试Connection pools中connection的有效性。
b)具体解决方案:
1、换一下JDBC驱动,JDBC3.1.0-alpha及以前版本会出现此问题,下载新的JDBC驱动
1、换一下JDBC驱动,JDBC3.1.0-alpha及以前版本会出现此问题,下载新的JDBC驱动
2、使用hibernate配置:
使用hibernate:
<property name="connection.autoReconnect">true</property> <!--这个是最主要的-->
<property name="connection.autoReconnectForPools">true</property>
<property name="connection.is-connection-validation-required">true</property>
加入以上property,可解决此问题,如果未使用hibernate等持久化管理框架,可在mysql的url中加入autoReconnect=true,这样就可以解决。
原 因很简单。在对数据库操作结束后关闭连接是正确的做法,没什么大问题。至于出现:No operations allowed after connection closed。这样的问题原因只有一个,你这里和数据库的连接Connection是一个Static的,程序共享这一个Connection。所以第一 次对数据库操作没问题,当把Connection关闭后,第二次还想操作数据库时Connection肯定不存在了。
---- >
我的解决方案:
因为未使用hibernate框架,而是Eclipselink, 因此在数据源配置时:
<connection-url>jdbc:mysql://xxx.xxx.xxx.xxx:3306/projectname?autoReconnect=true</connection-url>
阅读全文
0 0
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException问题
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException:
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
- Mysql异常:com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
- Mysql连接问题:com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establish
- ## com.MySQL.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establ
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Too many connections
- com.mysql.jdbc.exceptions MySQLNonTransientConnectionException
- mysql数据库报如下错误-----------com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data s
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after co
- Mysq 连接错误 com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Could not create con
- com.mysql.jdbc.exceptions.MySQLNonTransientConnectionException错误原因
- com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException
- com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
- com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxError Exception
- 异常:com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException
- Openlayers4中风场的实现
- 判断两个链表是否相交,如果相交如何找到第一个相交结点。
- iOS 图片上传使用base64或者二进制流上传头像
- 使用Jacob将Word、Excel转html,pdf转html
- 9月英语--进阶成长
- com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException
- 剑指offer——65.矩阵中的路径
- 读《编译原理》第十章至终章 指令级并行性
- Android组件定位不准的原因
- zookeeper
- 使用Yii2.0创建表单组件(input/单选按钮组/textarea文本域/文件上传...)
- BZOJ 1150: [CTSC2007]数据备份Backup 链表
- OpenGL学习:Per-fragment operation(3)-混合(blending)
- Arch美化——配置oh-my-zsh