SpringBoot配置Hikari连接池

Hikari连接池的优点:

1.快速:具有非常快的启动和关闭速度。其大小据说可以在一秒内动态调整(未尝试过)。

2.高效:具有极低的延迟和高效的并发性能。连接池只需要少量的线程进行管理,因此会产生较小                 的GC负载,同时可以支持高负载场景。

3.稳定:具有很好的稳定性和可靠性,它可以有效地避免由于连接泄漏、连接过期等问题导致的应                 用程序崩溃。

4.易于管理:有许多配置参数可以被开发人员根据需要进行调整。此外,它的错误日志非常详细,能够帮助开发人员快速直接的解决问题。

项目版本:SpringBoot 3.1.0     Java17

其是SpringBoot默认的连接池,因此jdbc中有其默认依赖:

<!--此依赖默认使用Hikari连接池-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

Hikari简单配置:

spring:
  datasource:
    type: com.zaxxer.hikari.HikariDataSource
    Hikari:
      # 连接池中允许的最小连接数。缺省值:10
      minimum-idle: 10
      # 连接池中允许的最大连接数。缺省值:10
      maximum-pool-size: 100
      # 自动提交
      auto-commit: true
      # 一个连接idle状态的最大时长(毫秒),超时则被释放(retired),缺省:10分钟
      idle-timeout: 600000
      # 连接池名字
      pool-name: YIXGHikariCP
      # 一 个连接的生命时长(毫秒),超时而且没被使用则被释放(retired),缺省:30分钟,建议设置比数据库超时时长少30秒
      max-lifetime: 1800000
      # 等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQLExcepti on, 缺省:30秒
      connection-timeout: 30000

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Spring Boot可以通过配置文件来配置数据库连接池。以下是配置步骤: 1. 在pom.xml文件中添加数据库连接池依赖,如HikariCP或Druid。 2. 在application.properties或application.yml文件中配置数据库连接池相关属性,如数据库URL、用户名、密码、最大连接数、最小连接数等。 3. 在Spring Boot应用程序中使用JdbcTemplate或MyBatis等ORM框架来访问数据库。 例如,使用HikariCP连接池配置示例: 在pom.xml文件中添加依赖: ``` <dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId> <version>3.4.5</version> </dependency> ``` 在application.properties文件中配置: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.hikari.maximum-pool-size=10 spring.datasource.hikari.minimum-idle=5 ``` 在Spring Boot应用程序中使用JdbcTemplate访问数据库: ``` @Autowired private JdbcTemplate jdbcTemplate; public void query() { List<Map<String, Object>> list = jdbcTemplate.queryForList("SELECT * FROM user"); for (Map<String, Object> map : list) { System.out.println(map); } } ``` ### 回答2: Spring Boot提供了很多开箱即用的配置,其中包括配置数据库连接池。下面给出了一些在Spring Boot配置常见数据库连接池的示例。 1. 配置tomcat连接池 在pom.xml中添加以下依赖: ```xml <dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-jdbc</artifactId> <version>${tomcat-jdbc.version}</version> </dependency> ``` 在application.properties中添加以下属性: ``` spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=username spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.tomcat.validation-query=SELECT 1 spring.datasource.tomcat.test-while-idle=true spring.datasource.tomcat.time-between-eviction-runs-millis=3600000 spring.datasource.tomcat.max-wait=10000 spring.datasource.tomcat.initial-size=5 spring.datasource.tomcat.max-active=20 spring.datasource.tomcat.min-idle=5 spring.datasource.tomcat.default-auto-commit=false spring.datasource.tomcat.remove-abandoned-on-borrow=true spring.datasource.tomcat.remove-abandoned-timeout=120 ``` 2. 配置Hikari连接池 在pom.xml中添加以下依赖: ```xml <dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId> <version>${hikaricp.version}</version> </dependency> ``` 在application.properties中添加以下属性: ``` spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=username spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.hikari.maximum-pool-size=20 spring.datasource.hikari.minimum-idle=5 spring.datasource.hikari.connection-timeout=30000 spring.datasource.hikari.idle-timeout=600000 spring.datasource.hikari.max-lifetime=1800000 ``` 3. 配置Druid连接池 在pom.xml中添加以下依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>${druid.version}</version> </dependency> ``` 在application.properties中添加以下属性: ``` spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=username spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.druid.initial-size=5 spring.datasource.druid.max-active=20 spring.datasource.druid.min-idle=5 spring.datasource.druid.max-wait=10000 spring.datasource.druid.remove-abandoned=true spring.datasource.druid.remove-abandoned-timeout=120 spring.datasource.druid.log-abandoned=true spring.datasource.druid.time-between-eviction-runs-millis=60000 spring.datasource.druid.min-evictable-idle-time-millis=300000 spring.datasource.druid.test-while-idle=true spring.datasource.druid.validation-query=SELECT 'x' ``` 需要注意的是,以上仅仅是不同数据库连接池的例子,实际上Spring Boot 支持多种配置方法。同时,在从以上配置示例中为我们示范出这些数据库连接池的连接参数,但具体的参数应该是根据实际应用场景而定,且不应到处复制粘贴,而应根据自己当前系统的资源状况来进行合理设置。通过正确参数和合理设置合理使用数据库连接池可以最大化地提高你的应用性能和可扩展性。 ### 回答3: Spring Boot是一个非常流行的基于Spring框架的Java应用程序开发平台。配置数据库连接池对于Web应用程序来说非常重要,因为连接池可以提高数据库操作的效率和性能。Spring Boot提供方便的方式来配置和使用各种数据库连接池,包括HikariCP、Tomcat JDBC Pool、DBCP2等。 以下是使用Spring Boot配置HikariCP连接池的步骤: 1. 添加HikariCP依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId> <version>3.4.5</version> </dependency> ``` 2. 配置数据源 在application.properties中添加以下数据源配置: ```properties spring.datasource.url=jdbc:mysql://localhost/testdb spring.datasource.username=dbuser spring.datasource.password=dbpass spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.hikari.maximum-pool-size=10 ``` 以上配置包括了数据库连接URL、用户名、密码、驱动类以及最大连接数等参数。HikariCP还有很多其他的配置参数可以设置,详见官方文档。 3. 使用数据源 使用Spring Boot的JdbcTemplate进行数据库操作,示例代码如下: ```java @Autowired JdbcTemplate jdbcTemplate; public void query() { List<Map<String, Object>> resultList = jdbcTemplate.queryForList("SELECT * FROM table_name"); } ``` 以上是Spring Boot配置HikariCP连接池的基本步骤。总的来说,Spring Boot提供了非常方便的方式来配置数据库连接池,开发人员无需关心太多底层细节,可以更专注于应用程序的业务逻辑实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值