在springboot项目中使用hikari数据源
1、首先是依赖的引入
如果使用的是springBoot的依赖就无须再引入hikariCP的依赖了,因为springBoot默认就引入了。
如果使用的是普通的spring项目则需在pom文件中引入依赖:
Java 8 thru 11 maven artifact:
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>3.4.1</version>
</dependency>
Java 7 maven artifact (maintenance mode):
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP-java7</artifactId>
<version>2.4.13</version>
</dependency>
Java 6 maven artifact (maintenance mode):
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP-java6</artifactId>
<version>2.3.13</version>
</dependency>
jdk版本最低使用6.
2、引入依赖后要到配置文件中配置hikari的基础配置
spring:
datasource: # 数据源的相关配置
type: com.zaxxer.hikari.HikariDataSource # 数据源类型:HikariCP
driver-class-name: com.mysql.cj.jdbc.Driver # mysql 5.1 用 com.mysql.jdbc.Driver 8.1 用 com.mysql.cj.jdbc.Driver# mysql驱动
url: jdbc:mysql://localhost:3306/foodie-shop-dev?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
#解决mysql驱动5.1 mysql数据库8.1会报错 java.sql.SQLException: Unknown system variable 'tx_read_only' 的办法是在URL后面加&useLocalSessionState=true
username: consonline
password: sszfcons
hikari:
connection-timeout: 30000 # 等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQ
minimum-idle: 5 # 最小连接数
maximum-pool-size: 20 # 最大连接数
auto-commit: true # 自动提交
idle-timeout: 600000 # 连接超时的最大时长(毫秒),超时则被释放(retired),默认:10分钟
pool-name: DateSourceHikariCP # 连接池名字
max-lifetime: 1800000 # 连接的生命时长(毫秒),超时而且没被使用则被释放(retired),默认:30分钟
connection-test-query: SELECT 1
这里使用的是mysql8的数据库驱动包。在注释里也写明了mysql8数据驱动会出现的问题以及解决办法。