hikaricp 使用(配置問題)


HikariPool-1 - Failed to validate connection

環境,版本:

  win7,jdk7,HikariCP-java7 (2.4.13)

報錯信息:

  [com.zaxxer.hikari.pool.PoolBase]HikariPool-1 - Failed to validate connection com.mysql.jdbc.JDBC4Connection@3d62bf75 (Communications link failure
The last packet successfully received from the server was 330,589 milliseconds ago.  The last packet sent successfully to the server was 5,015 milliseconds ago.)

解決:

修改數據源的配置,hikaricp配置如下:

 

<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"
		destroy-method="shutdown">
		<property name="driverClassName" value="${jdbc.driver}" />
		<property name="jdbcUrl" value="${jdbc.jdbcUrl}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />

		<property name="connectionTestQuery" value="SELECT 1" />
		<!-- 生效超時 -->
		<property name="validationTimeout" value="3000" />
		<!-- 連接只讀數據庫時配置為true, 保證安全 -->
		<property name="readOnly" value="false" />
		<!-- 等待連接池分配連接的最大時長(毫秒),超過這個時長還沒可用的連接則發生SQLException, 缺省:30秒 -->
		<property name="connectionTimeout" value="60000" />
		<!-- 一個連接idle狀態的最大時長(毫秒),超時則被釋放(retired),缺省:10分鍾 -->
		<property name="idleTimeout" value="60000" />
		<!-- 一個連接的生命時長(毫秒),超時而且沒被使用則被釋放(retired),缺省:30分鍾,建議設置比數據庫超時時長少30秒,參考MySQL 
			wait_timeout參數(show variables like '%timeout%';) -->
		<property name="maxLifetime" value="60000" />
		<!-- 連接池中允許的最大連接數。缺省值:10;推薦的公式:((core_count * 2) + effective_spindle_count) -->
		<property name="maximumPoolSize" value="10" />

	</bean>

 

按照如上的配置validationTimeoutconnectionTimeoutidleTimeout,maxLifetime 后能夠解決該警告信息

原因分析:

在間隔一段時間后,重新請求時,在如下的標記處會捕捉到異常,從而導致報出警告信息。

 


免責聲明!

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



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