HikariCP数据库连接池中文使用手册

转载 

原文地址:https://blog.csdn.net/eguid/article/details/108635464

HikariCP 数据库连接池


迄今为止,性能最好,速度最快的数据库连接池。

 

依赖项


Java 8 thru 11 maven artifact:


    <dependency>
        <groupId>com.zaxxer</groupId>
        <artifactId>HikariCP</artifactId>
        <version>3.4.5</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>

HikariCP的jdbc驱动名和数据源类名对应列表


Here is a list of JDBC DataSource classes for popular databases:
Database             Driver              DataSource class
Apache Derby      Derby                 org.apache.derby.jdbc.ClientDataSource
Firebird                 Jaybird               org.firebirdsql.ds.FBSimpleDataSource
H2                         H2                      org.h2.jdbcx.JdbcDataSource
HSQLDB               HSQLDB            org.hsqldb.jdbc.JDBCDataSource
IBM                       DB2   IBM JCC   com.ibm.db2.jcc.DB2SimpleDataSource
IBM Informix         IBM Informix       com.informix.jdbcx.IfxDataSource
MS SQL Server    Microsoft             com.microsoft.sqlserver.jdbc.SQLServerDataSource
MySQL                 Connector/J         com.mysql.jdbc.jdbc2.optional.MysqlDataSource
MariaDB               MariaDB              org.mariadb.jdbc.MariaDbDataSource
Oracle                  Oracle                  oracle.jdbc.pool.OracleDataSource
OrientDB              OrientDB             com.orientechnologies.orient.jdbc.OrientDataSource
PostgreSQL          pgjdbc-ng            com.impossibl.postgres.jdbc.PGDataSource
PostgreSQL          PostgreSQL        org.postgresql.ds.PGSimpleDataSource
SAP MaxDB         SAP                     com.sap.dbtech.jdbc.DriverSapDB
SQLite                  xerial                   org.sqlite.SQLiteDataSource
SyBase                 jConnect             com.sybase.jdbc4.jdbc.SybDataSource

补充(实际上postgreSQL官方jdbc驱动使用下面这个类名):
PostgreSQL    PostgreSQL    org.postgresql.Driver

 

HikariCP配置属性全览


HikariCP带有合理的默认值,在大多数部署中都可以正常运行,而无需进行其他调整。每个属性都是可选的,但以下标记的“必需”除外。

📎HikariCP使用毫秒作为所有时间值。
HikariCP依靠准确的计时器来提高性能和可靠性。您的服务器必须与时间源(例如NTP服务器)同步。特别是如果您的服务器在虚拟机中运行。为什么?在这里阅读更多。不要依靠虚拟机监控程序设置来“同步”虚拟机的时钟。在虚拟机内部配置时间源同步。如果您是由于时间缺乏同步而寻求支持,则会在Twitter上公开嘲讽您。

这个是真的,如果因为时间漂移问题导致无法获取连接这个问题去问作者会被喷。

Essentials(必需的配置)
🔠dataSourceClassName
这是JDBC驱动程序提供的DataSource类的名称。有关特定的JDBC驱动程序的信息,请查阅文档以获取该类名,或参阅下表。注意不支持XA数据源。 XA需要像bitronix这样的真实事务管理器。请注意,如果您使用jdbcUrl进行基于“老式”基于DriverManager的JDBC驱动程序配置,则不需要此属性。默认值:无

- 或 -

🔠jdbcUrl
此属性指示HikariCP使用“基于DriverManager的”配置。我们认为基于数据源的配置(上文)优于多种原因(请参见下文),但是对于许多部署而言,差异不大。当将此属性与“旧”驱动程序一起使用时,您可能还需要设置driverClassName属性,但首先尝试不使用该属性。请注意,如果使用此属性,则仍可以使用DataSource属性来配置驱动程序,实际上,建议您对URL本身中指定的驱动程序参数进行推荐。默认值:无

实际上,大部分实际应用中,HikariCP都不能通过jdbcUrl解析出正确的driverClassName,所以我认为driverClassName是必须的,所以我把driverClassName从不常用配置提升到必须配置。

🔠driverClassName
HikariCP将尝试仅通过jdbcUrl通过DriverManager来解析驱动程序,但是对于某些较旧的驱动程序,还必须指定driverClassName。除非获得明显的错误消息指示未找到驱动程序,否则请忽略此属性。默认值:无

🔠username(用户名)
此属性设置从基础驱动程序获取连接时使用的默认身份验证用户名。请注意,对于DataSources,这可以通过在基础DataSource上调用DataSource.getConnection(* username *,password)以非常确定的方式进行。但是,对于基于驱动程序的配置,每个驱动程序都是不同的。对于基于驱动程序的情况,HikariCP将使用此用户名属性在传递给驱动程序的DriverManager.getConnection(jdbcUrl,props)调用的属性中设置用户属性。如果这不是您所需要的,请完全跳过此方法,并例如调用addDataSourceProperty(“ username”,...)。默认值:无

🔠password(密码)
此属性设置从基础驱动程序获取连接时使用的默认身份验证密码。请注意,对于DataSources,这可以通过在基础DataSource上调用DataSource.getConnection(username,* password *)以非常确定的方式进行。但是,对于基于驱动程序的配置,每个驱动程序都是不同的。对于基于驱动程序的情况,HikariCP将使用此密码属性在传递给驱动程序的DriverManager.getConnection(jdbcUrl,props)调用的属性中设置密码属性。如果这不是您所需要的,请完全跳过此方法,例如,调用addDataSourceProperty(“ pass”,...)。默认值:无

Frequently used(以下是经常使用的配置属性)

autoCommit
此属性控制从池返回的连接的默认自动提交行为。它是一个布尔值。默认值:true

⌚connectionTimeout
此属性控制客户端(即您)等待来自池的连接的最大毫秒数。如果超过此时间而没有可用的连接,则会抛出SQLException。可接受的最低连接超时为250 ms。默认值:30000(30秒)

⌚idleTimeout
此属性控制允许连接在池中保持空闲状态的最长时间。仅当minimumIdle定义为小于maximumPoolSize时,此设置才适用。一旦池达到MinimumIdle连接,空闲连接将不被取消。连接是否以空闲状态退役,最大变化为+30秒,平均变化为+15秒。在此超时之前,连接永远不会因为空闲而退役。值为0表示永远不会从池中删除空闲连接。最小允许值为10000ms(10秒)。默认值:600000(10分钟)

⌚maxLifetime(最大生存时间)
此属性控制池中连接的最大生存期。使用中的连接永远不会退出,只有在关闭连接后才将其删除。在逐个连接的基础上,应用较小的负衰减以避免池中的质量消灭。我们强烈建议设置此值,它应该比任何数据库或基础结构施加的连接时间限制短几秒钟。值0表示没有最大生存期(无限生存期),当然要遵守idleTimeout设置。最小允许值为30000ms(30秒)。默认值:1800000(30分钟)

connectionTestQuery(连接测试查询)
如果您的驱动程序支持JDBC4,我们强烈建议不要设置此属性。这是针对不支持JDBC4 Connection.isValid()API的“旧版”驱动程序的。这是将在从池中为您提供连接之前执行的查询,以验证与数据库的连接仍然有效。同样,尝试运行不带该属性的池,如果驱动程序不兼容JDBC4,HikariCP将记录错误。默认值:无

🔢minimumIdle(最小空闲连接数)
此属性控制HikariCP尝试在池中维护的最小空闲连接数。如果空闲连接下降到该值以下,并且池中的总连接数小于maximumPoolSize,则HikariCP将尽最大努力快速而有效地添加其他连接。但是,为了获得最佳性能和对峰值需求的响应能力,建议不要设置该值,而应让HikariCP充当固定大小的连接池。默认值:与maximumPoolSize相同

🔢maximumPoolSize(最大空闲连接数)
此属性控制允许池达到的最大大小,包括空闲和使用中的连接。基本上,此值将确定到数据库后端的最大实际连接数。合理的值最好由您的执行环境确定。当池达到此大小,并且没有空闲连接可用时,在超时之前,对getConnection()的调用将最多阻塞connectionTimeout毫秒。请阅读有关池大小的信息。默认值:10

📈metricRegistry
此属性仅可通过编程配置或IoC容器使用。此属性允许您指定Codahale / Dropwizard MetricRegistry的实例,池将使用该实例来记录各种指标。有关详细信息,请参见Metrics Wiki页面。默认值:无

📈healthCheckRegistry
此属性仅可通过编程配置或IoC容器使用。此属性允许您指定Codahale / Dropwizard HealthCheckRegistry的实例,池将使用该实例来报告当前的健康信息。有关详细信息,请参见运行状况检查Wiki页面。默认值:无

🔠poolName
该属性表示连接池的用户定义名称,主要出现在日志记录和JMX管理控制台中,以识别池和池配置。默认值:自动生成

Infrequently used(以下是很少的使用配置属性)
⌚initializationFailTimeout
此属性控制如果无法为初始连接成功播种池,则池是否将“快速失败”。任何正数都将视为尝试获取初始连接的毫秒数;在此期间,应用程序线程将被阻止。如果在此超时发生之前无法获取连接,则将引发异常。此超时在connectionTimeout时间段之后应用。如果值为零(0),则HikariCP将尝试获取并验证连接。如果获得连接但验证失败,则将引发异常并且池不启动。但是,如果无法获得连接,则池将启动,但是以后获得连接的努力可能会失败。小于零的值将绕过任何初始连接尝试,并且池将在尝试在后台获取连接时立即启动。因此,以后获得连接的努力可能会失败。默认值:1

❎isolateInternalQueries
此属性确定HikariCP是否在其自身的事务中隔离内部池查询,例如连接活动测试。由于这些通常是只读查询,因此几乎没有必要将它们封装在自己的事务中。仅当禁用autoCommit时,此属性才适用。默认值:false

❎allowPoolSuspension
此属性控制是否可以通过JMX暂停和恢复池。这对于某些故障转移自动化方案很有用。当池挂起时,对getConnection()的调用不会超时,并且将保持到恢复池为止。默认值:false

❎readOnly
此属性控制默认情况下从池获得的连接是否处于只读模式。请注意,某些数据库不支持只读模式的概念,而另一些数据库在将Connection设置为只读时提供查询优化。是否需要此属性在很大程度上取决于您的应用程序和数据库。默认值:false

❎registerMbeans
此属性控制是否注册JMX管理Bean(“ MBean”)。默认值:false

🔠catalog
此属性为支持目录概念的数据库设置默认目录。如果未指定此属性,则使用JDBC驱动程序定义的默认目录。默认值:驱动程序默认值

🔠connectionInitSql
此属性设置一个SQL语句,该语句将在每次创建新连接后执行,然后再将其添加到池中。如果此SQL无效或引发异常,它将被视为连接失败,并且将遵循标准的重试逻辑。默认值:无

 

transactionIsolation
此属性控制从池返回的连接的默认事务隔离级别。如果未指定此属性,则使用JDBC驱动程序定义的默认事务隔离级别。仅当您具有所有查询通用的特定隔离要求时,才使用此属性。此属性的值是Connection类中的常量名称,例如TRANSACTION_READ_COMMITTED,TRANSACTION_REPEATABLE_READ等。默认值:驱动程序默认值

⌚validationTimeout
此属性控制将测试连接的活动性的最长时间。此值必须小于connectionTimeout。可接受的最低验证超时为250毫秒。默认值:5000

⌚leakDetectionThreshold
此属性控制在记录表示可能的连接泄漏的消息之前,连接可以离开池的时间。值为0表示禁用泄漏检测。启用泄漏检测的最低可接受值为2000(2秒)。默认值:0

➡dataSource
此属性仅可通过编程配置或IoC容器使用。此属性使您可以直接设置要由池包装的DataSource实例,而不是让HikariCP通过反射构造它。这在某些依赖项注入框架中可能很有用。指定此属性后,将忽略dataSourceClassName属性和所有特定于DataSource的属性。默认值:无

🔠schema
此属性为支持模式概念的数据库设置默认模式。如果未指定此属性,则使用JDBC驱动程序定义的默认模式。默认值:驱动程序默认值

➡threadFactory
此属性仅可通过编程配置或IoC容器使用。此属性允许您设置java.util.concurrent.ThreadFactory的实例,该实例将用于创建池使用的所有线程。在某些只能通过应用程序容器提供的ThreadFactory创建线程的受限执行环境中,需要使用它。默认值:无

➡scheduledExecutor
此属性仅可通过编程配置或IoC容器使用。该属性允许您设置java.util.concurrent.ScheduledExecutorService的实例,该实例将用于各种内部计划的任务。如果向HikariCP提供ScheduledThreadPoolExecutor实例,则建议使用setRemoveOnCancelPolicy(true)。默认值:无

 

在spring配置中如何初始化HikariCP的datasource

使用com.zaxxer.hikari.HikariDataSource类作为连接池初始化类

<!--连接池配置-->
    <bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource" destroy-method="close"> 
        <property name="poolName" value="${hikari.poolName}" />
        <property name="autoCommit" value="${hikari.autoCommit}" />
        
        <property name="driverClassName" value="${hikari.driverClassName}"></property>
        <property name="jdbcUrl" value="${hikari.jdbcUrl}" />
        <property name="username" value="${hikari.username}" />
        <property name="password" value="${hikari.password}" />
        
        <property name="maximumPoolSize" value="${hikari.maximumPoolSize}" />
        <property name="minimumIdle" value="${hikari.minimumIdle}" />
        <property name="connectionTimeout" value="${hikari.connectionTimeout}" />
        <property name="idleTimeout" value="${hikari.idleTimeout}" />
        <property name="maxLifetime" value="${hikari.maxLifetime}" />
        <property name="connectionTestQuery" value="${hikari.connectionTestQuery}" /> 
    </bean>

在springboot中如何初始化HikariCP

在application.properties配置文件中配置

spring.datasource.type=com.zaxxer.hikari.HikariDataSource

其他参数与springboot正常连接配置相同,对应参数值参考上面的spring连接池配置参数

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值