在 Spring Boot 中使用 HikariCP 连接池,需要进行以下配置:
- 添加 HikariCP 依赖
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
</dependency>
- 在 application.properties 中配置数据源连接信息
spring.datasource.url=jdbc:mysql://localhost:3306/db_name?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false&maxReconnects=10
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
- 配置 HikariCP 数据源
@Configuration
public class DataSourceConfig {
@Autowired
private Environment env;
@Bean(name = "dataSource")
public DataSource dataSource() {
HikariDataSource dataSource = new HikariDataSource();
dataSource.setJdbcUrl(env.getProperty("spring.datasource.url"));
dataSource.setUsername(env.getProperty("spring.datasource.username"));
dataSource.setPassword(env.getProperty("spring.datasource.password"));
dataSource.setDriverClassName(env.getProperty("spring.datasource.driver-class-name"));
// 其他配置项,可根据实际需要进行调整
dataSource.setMaximumPoolSize(Integer.parseInt(env.getProperty("spring.datasource.hikari.maximum-pool-size", "20")));
dataSource.setMinimumIdle(Integer.parseInt(env.getProperty("spring.datasource.hikari.minimum-idle", "5")));
dataSource.setConnectionTimeout(Long.parseLong(env.getProperty("spring.datasource.hikari.connection-timeout", "30000")));
dataSource.setIdleTimeout(Long.parseLong(env.getProperty("spring.datasource.hikari.idle-timeout", "600000")));
dataSource.setMaxLifetime(Long.parseLong(env.getProperty("spring.datasource.hikari.max-lifetime", "1800000")));
dataSource.setAutoCommit(Boolean.parseBoolean(env.getProperty("spring.datasource.hikari.auto-commit", "true")));
return dataSource;
}
}
- 在需要使用数据源的地方,如 Service 层中,通过 @Autowired 注入 DataSource
@Service
public class UserServiceImpl implements UserService {
@Autowired
private DataSource dataSource;
// ...
}
通过以上配置,即可成功使用 HikariCP 连接池对数据库进行操作。需要注意的是,HikariCP 的默认配置已经足够优秀,一般不需要进行过多的调整。如果需要进行调整,建议根据具体应用场景进行测试和调优。