1. 配置
spring.datasource.type=com.zaxxer.hikari.HikariDataSource
spring.datasource.hikari.minimum-idle=5
spring.datasource.hikari.maximum-pool-size=15
spring.datasource.hikari.auto-commit=true
spring.datasource.hikari.idle-timeout=60000
spring.datasource.hikari.pool-name=DatebookHikariCP
spring.datasource.hikari.max-lifetime=300000
spring.datasource.hikari.connection-timeout=30000
spring.datasource.hikari.connection-test-query=SELECT 1
配置仅供参考,可根据自己需要进行修改;
启动后
2019-03-06更新:yaml
datasource:
hikari:
#自动提交
auto-commit: true
connection-test-query: SELECT 1
#等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQLException, 缺省:30秒 -->
connection-timeout: 30000
# 一个连接idle状态的最大时长(毫秒),超时则被释放(retired),缺省:10分钟 -->
idle-timeout: 600000
#一个连接的生命时长(毫秒),超时而且没被使用则被释放(retired),缺省:30分钟,
#建议设置比数据库超时时长少30秒,参考MySQL wait_timeout参数(show variables like '%timeout%';) -->
max-lifetime: 620000
#连接池中允许的最大连接数。缺省值:10;推荐的公式:((core_count * 2) + effective_spindle_count) -->
maximum-pool-size: 30
#池中维护的最小空闲连接数
minimum-idle: 5
pool-name: DatebookHikariCP
read-only: false
type: com.zaxxer.hikari.HikariDataSource
2020-04-06 项目中使用优化后:
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.jdbc.Driver
hikari:
#自动提交
auto-commit: true
connection-test-query: SELECT 1
#等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQLException, 缺省:30秒 -->
connection-timeout: 30000
# 一个连接idle状态的最大时长(毫秒),超时则被释放(retired),缺省:10分钟 -->
idle-timeout: 300000
#一个连接的生命时长(毫秒),超时而且没被使用则被释放(retired),缺省:30分钟
max-lifetime: 1800000
#连接池中允许的最大连接数。缺省值:10;推荐的公式:((core_count * 2) + effective_spindle_count) -->
maximum-pool-size: 20
#池中维护的最小空闲连接数,如果当连接池空闲连接少于 minimumIdle,
#而且总共连接数不大于 maximumPoolSize 时,HikariCP 会尽力补充新的连接。为了性能考虑,不建议设置此值,而是让 HikariCP 把连接池当做固定大小的处理,默认 minimumIdle 与 maximumPoolSize 一样。
minimum-idle: 5
pool-name: DatebookHikariCP
read-only: false
#验证与数据库连接的有效时间
validation-timeout: 5000