• 再淡spring jdbc 连接池断开重连设置



    先看一段错误日志:

    ### Error querying database.  Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.
    ### The error may exist in file …………]
    ### The error may involve .....
    ### The error occurred while executing a query
    ### Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.
    ; SQL []; No operations allowed after connection closed.; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.
    


    这个是连接池断开后(网络、数据库断开)。没有确认池里的连接继续可用的情况下,去操作数据库。

    网上一搜,解决的方法一大堆,基本配置例如以下:


    	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    		<property name="driverClassName" value="${jdbc.driverClassName}" />
    		<property name="url" value="${jdbc.url}" />
    		<property name="username" value="${jdbc.username}" />
    		<property name="password" value="${jdbc.password}" />
    		<!-- 队列中的最小等待数 -->
    		<property name="minIdle" value="${jdbc.minIdle}"></property>
    		<!-- 队列中的最大等待数 -->
    		<property name="maxIdle" value="${jdbc.maxIdle}"></property>
    		<!-- 最长等待时间。单位毫秒 -->
    		<property name="maxWait" value="${jdbc.maxWait}"></property>
    		<!-- 最大活跃数 -->
    		<property name="maxActive" value="${jdbc.maxActive}"></property>
    		<property name="initialSize" value="${jdbc.initialSize}"></property>
    		<property name="validationQuery" value="select 1"/>
    		<property name="testOnBorrow" value="false"/>
    		<property name="testWhileIdle" value="true"/>
    		<property name="testOnReturn" value="false"/>
    		<property name="numTestsPerEvictionRun" value="${jdbc.maxActive}"/>
    		<!-- 5 min 每5分钟检測空暇连接超过10分钟的连接-->
    		<property name="timeBetweenEvictionRunsMillis" value="300000" />  
    		<property name="minEvictableIdleTimeMillis" value="600000" /> 
    		<property name="removeAbandoned" value="true"/>
    	</bean>


    但是,这就够了吗?

    一開始放到自己的环境上是没实用的,还是报错了。

    继续努力,最后是攻克了。


    第一要理解连接池的各项配置(上面)

    第二是要知道mysql中wait_timeout的设置

    两点结合才干确定连接池在项目中的合理正确配置。


    假设wait_timeout设置成非常大一个值,比如一年,那么上面的配置非常多情况下都是正确的。

    假设wait_timeout设置成非常小,如1分钟,那么上面的配置是有问题的。

    由于server1分钟就把空暇连接断开了,client过了5分钟再去检查连接情况,那有什么意义?先前就是没理解被误导了,把timeBetweenEvictionRunsMillis设置了一个比較大的值,所以一直有问题。包含所说的8小时问题也是源于此(mysql数据库默认是空暇8小时断开)。


    我的原因是mysql的wait_timeout的值设置小了。而client检測的间隔时间过大。


    正确的做法是:

    连接池配置中的timeBetweenEvictionRunsMillis和

    minEvictableIdleTimeMillis的
    时间小于或者等于mysql数据库中wait_timeout的时间。


  • 相关阅读:
    Mybatis(二) Mybatis通用的写法
    Mybatis(一)Mybatis相关概念
    NodeJS添加Jquery依赖
    安卓、IOS端AEC密钥加密 Java端密钥解密通用实现(16进制表现形式)
    关于博客园首页及详情页美化的代码
    MD5用户密码加密工具类 MD5Util
    .Net Core跨平台应用研究-CustomSerialPort(增强型跨平台串口类库)
    FtpServer穿透内网访问配置踩坑笔记
    .Net Core之编辑json配置文件
    玩转MQTT-阿里云之MQTT使用(下)
  • 原文地址:https://www.cnblogs.com/yxwkf/p/5155427.html
Copyright © 2020-2023  润新知