温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

spring boot中如何配置hikari连接池属性方式

发布时间:2021-10-08 09:56:38 来源:亿速云 阅读:520 作者:小新 栏目:开发技术

小编给大家分享一下spring boot中如何配置hikari连接池属性方式,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

    spring boot配置hikari连接池属性

    事件起因与一个简单应用经常发生Young GC,甚至在没有请求量的情况下也经常发生GC (Allocation Failure),后来使用mat工具进行分析,发现mysql连接相关的class居然占了40%+堆内空间。

    才发现spring boot的连接池大小没有配置,默认是10个连接,但实际上该应用不需要这么多。

    The class "com.mysql.cj.jdbc.AbandonedConnectionCleanupThread", 
    loaded by "org.apache.catalina.loader.ParallelWebappClassLoader @ 0xf8dfdf30", 
    occupies 19,279,792 (41.23%) bytes. 
    The memory is accumulated in one instance of "java.util.concurrent.ConcurrentHashMap$Node[]" 
    loaded by "<system class loader>".

    spring-boot默认连接池

    spring-boot中,根据以下3个优先级加载连接池

    1)如果classpath中有HikariCP,优先选择它

    2)如果Tomcat pooling 连接池可用,就会选择它

    3)如果以上都没有,则会选择Commons DBCP2连接池

    Hikari配置

    这里我们做一个非常低的配置(这个仅仅是一个访问量非常低的系统),如果默认的服务器,建议使用默认配置就足够了。

    spring.datasource.hikari.maximum-pool-size=2
    spring.datasource.hikari.minimum-idle=1
    spring.datasource.hikari.idle-timeout=600000
    spring.datasource.hikari.max-lifetime=1800000
    spring.datasource.hikari.connection-timeout=500
    spring.datasource.hikari.login-timeout=500
    spring.datasource.hikari.validation-timeout=1000
    spring.datasource.hikari.initialization-fail-timeout=1000

    参考链接

    Hikari连接池配置说明

    ## 数据库配置
    spring.datasource.type=com.zaxxer.hikari.HikariDataSource
    spring.datasource.driverClassName = com.mysql.jdbc.Driver
    spring.datasource.url = jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf-8&useSSL=false
    spring.datasource.username = root
    spring.datasource.password = root
    ##  Hikari 连接池配置 ------ 详细配置请访问:https://github.com/brettwooldridge/HikariCP
    ## 最小空闲连接数量
    spring.datasource.hikari.minimum-idle=5
    ## 空闲连接存活最大时间,默认600000(10分钟)
    spring.datasource.hikari.idle-timeout=180000
    ## 连接池最大连接数,默认是10
    spring.datasource.hikari.maximum-pool-size=10
    ## 此属性控制从池返回的连接的默认自动提交行为,默认值:true
    spring.datasource.hikari.auto-commit=true
    ## 连接池名称
    spring.datasource.hikari.pool-name=MyHikariCP
    ## 此属性控制池中连接的最长生命周期,值0表示无限生命周期,默认1800000即30分钟
    spring.datasource.hikari.max-lifetime=1800000
    ## 数据库连接超时时间,默认30秒,即30000
    spring.datasource.hikari.connection-timeout=30000
    spring.datasource.hikari.connection-test-query=SELECT 1

    以上是“spring boot中如何配置hikari连接池属性方式”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI