在SpringBoot 1.5.3上使用gradle引入hikariCP
hikari来源于日语,是“光”的意思,号称“史上最快数据库连接池”,也是springboot2.0最新版默认的连接池。但是springboot1.5.x的项目也是可以使用的。
springboot1.5.x默认的数据库连接池是tomcat-jdbc连接池,要迁移到hikari连接池只需要几步配置上的修改:
build.gradle文件
1、先将默认的tomcat connnection pool从依赖中移除
compile("org.springframework.boot:spring-boot-starter-data-jpa:1.5.3.RELEASE"){ exclude group: 'org.apache.tomcat', module: 'tomcat-jdbc' }
2、引入依赖
compile group: 'com.zaxxer', name: 'HikariCP', version: '3.4.1'
3、application.properties文件中配置连接池属性
spring.datasource.type=com.zaxxer.hikari.HikariDataSource spring.datasource.hikari.pool-name=SomeThingHikariCP spring.datasource.hikari.minimum-idle=5 spring.datasource.hikari.idle-timeout=600000 spring.datasource.hikari.maximum-pool-size=20 spring.datasource.hikari.auto-commit=true spring.datasource.hikari.max-lifetime=1800000 spring.datasource.hikari.connection-timeout=6000 //spring.datasource.hikari.connection-test-query=SELECT 1 FROM DUAL //配置了这个query则每次拿连接的时候用这个query测试,否则就使用java.sql.Connection的isValid测试 推荐jdbc4不配
原来的spring.datasource.tomcat.xxxx就需要注释掉了。
重启工程,控制台中会见到如下日志
...
com.zaxxer.hikari.HikariDataSource [110] - AppUserHikariCP - Starting...
com.zaxxer.hikari.pool.PoolBase [527] - AppUserHikariCP - Driver does not support get/set network timeout for connections. (com.mysql.jdbc.JDBC4Connection.getNetworkTimeout()I)
com.zaxxer.hikari.HikariDataSource [123] - AppUserHikariCP - Start completed.
...
说明数据库连接池迁移成功。
出现上面红字需要升级一下mysql驱动,笔者是把mysql-connector-java从5.1.18升级到5.1.47解决了这个问题。但是似乎有这个提示也可以正常使用。