再淡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的時間。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM