连接池配置解决mysql 8小时问题:Connection reset by peer: socket write error

mysql数据库的客户端连接在闲置8个小时(28800秒)之后会自动断开,在java项目中,如果你使用了连接池,不管是c3p0,还是阿里的数据源DRUID,亦或是dbcp,还是其他连接池,都会有这个问题,听别人一般称作“mysql 8小时问题”。

具体现象:比如你项目使用的是c3p0,配置好了连接池之后,在项目启动了,你就离开了,项目没有任何人使用,在8个小时之后,再去点击操作mysql数据库的操作(比如,查询一个学生列表),就会报错:

org.springframework.jdbc.support.MetaDataAccessException: Error while extracting DatabaseMetaData; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.

........省略部分堆栈报错信息

 

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.

........省略部分堆栈报错信息

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

 

The last packet successfully received from the server was 53,692,968 milliseconds ago.  The last packet sent successfully to the server was 53,692,978 milliseconds ago.

........省略部分堆栈报错信息

Caused by: java.net.SocketException: Connection reset by peer: socket write error

at java.net.SocketOutputStream.socketWrite0(Native Method)

at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:111)

at java.net.SocketOutputStream.write(SocketOutputStream.java:155)

at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:82)

at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:140)

at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:3634)

... 95 common frames omitted

这时候需要在c3p0的配置里加上如下两句:

<property name="idleConnectionTestPeriod" value="28000" />
<property name="maxIdleTime" value="28000" />

maxIdleTime=28000表示c3p0里面的连接在28000秒(<28800秒)后自动销毁,重新创建新的连接,这样就避免了你在从连接池获取连接的时候拿到已经被mysql单方面销毁的连接。

完整的c3p0配置参考:

	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="${c3p0.driverClass}" />
		<property name="jdbcUrl" value="${c3p0.jdbcUrl}" />
		<property name="user" value="${c3p0.user}" />
		<property name="password" value="${c3p0.password}" />
		<property name="maxPoolSize" value="${c3p0.maxPoolSize}" />
		<property name="minPoolSize" value="${c3p0.minPoolSize}" />
		<property name="initialPoolSize" value="${c3p0.initialPoolSize}" />
		<property name="acquireIncrement" value="${c3p0.acquireIncrement}" />
		<!-- mysql默认28800s/60/60=8h后单方面关闭空闲连接,c3p0默认经过600万秒才释放 -->
		<property name="idleConnectionTestPeriod" value="28000" />
		<property name="maxIdleTime" value="28000" />
	</bean>

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值