最近遇到一个关于数据库连接池的问题:
报错详情:
org.springframework.transaction.CannotCreateTransactionException: Could not openJDBCConnection for transaction; nested exception is java.sql.SQLTransientConnectionException:HikariPool-3 - Connection is not available, request timed out after 30001ms.
大致意思就是创建事务异常,链接超过30001ms没有相应。
解决问题
其实在我们开发中可能会存在数据库100个连接数确实不够的情况,这是要经过日志及分析后才能确定的。如果最终发现确实是项目需要更多的连接数,那就要修改数据库连接池相应的配置了,加大数据库的最大连接数。
springboot 2.0 默认连接池是Hikari,我就以这个为例,来修改相应的数据库连接池的配置:可以加大–连接池中维护的最小空闲连接数
spring:
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/user1?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
username: root
password: root
# Hikari 连接池配置
hikari:
# 连接池中维护的最小空闲连接数
minimum-idle: 100
# 数据库连接超时时间,默认30秒,即30000
connection-timeout: 30000
# 空闲连接存活最大时间,默认600000(10分钟)
idle-timeout: 1800000
# 连接池最大连接数,默认是100
maximum-pool-size: 200
# 控制从池返回的连接的默认自动提交行为,默认值:true
auto-commit: true
# 控制连接池中连接的最长生命周期,值0表示无限生命周期,默认1800000即30分钟
max-lifetime: 1800000
#连接将被测试活动的最大时间量
validation-timeout: 30000
connection-test-query: SELECT 1
connection-init-sql: SET NAMES utf8mb4