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 后能够解决该警告信息

原因分析:

在间隔一段时间后,重新请求时,在如下的标记处会捕捉到异常,从而导致报出警告信息。

 

posted @ 2017-12-29 11:54  天丶依  阅读(14961)  评论(0编辑  收藏  举报