Spring實現(xiàn)HikariCP連接池的示例代碼
上兩篇文章,我們講到了Spring中如何配置單數(shù)據(jù)源和多數(shù)據(jù)源,配置數(shù)據(jù)源的時候,連接池有很多選擇,在SpringBoot 1.0中使用的是Tomcat的DataSource,在SpringBoot 2.0中,我們使用默認(rèn)連接池是HikariCP,本文講一下HikariCP。
為什么SpringBoot 2.0要選擇HikariCP來作為默認(rèn)的連接池呢?
我們先看一下官網(wǎng)的一張對比圖。

一個連接周期定義為單個DataSource.getConnection()/ Connection.close()。 一個語句周期定義為單個Connection.prepareStatement(), Statement.execute(), Statement.close()
從上圖看出,HikariCP和常見的連接池相比,優(yōu)勢非常明顯。
為什么HikariCP那么快呢?根據(jù)官網(wǎng)概要總結(jié)了以下幾點字
- 字節(jié)碼精簡 :字節(jié)碼級別優(yōu)化(很多⽅法通過 JavaAssist ⽣成),直到編譯后的字節(jié)碼最少,這樣,CPU緩存可以加載更多的程序代碼;
- 優(yōu)化代理和攔截器:減少代碼,例如HikariCP的Statement proxy只有100行代碼,只有BoneCP的十分之一;
- 自定義數(shù)組類型:(FastStatementList)代替ArrayList:避免每次get()調(diào)用都要進(jìn)行range check,避免調(diào)用remove()時的從頭到尾的掃描;
- 自定義集合類型(ConcurrentBag:提高并發(fā)讀寫的效率;
- 代理類的優(yōu)化(⽐如,⽤ invokestatic 代替了 invokevirtual)
- 其他針對BoneCP缺陷的優(yōu)化,比如對于耗時超過一個CPU時間片的方法調(diào)用的研究(但沒說具體怎么優(yōu)化)。
既然HikariCP那么快,接下來就看一下在Spring中怎么使用HikariCP?
在Spring Boot 2.x中
- 默認(rèn)使⽤ HikariCP
- 配置 spring.datasource.hikari.* 配置
在Spring Boot 1.x中
- 默認(rèn)使⽤ Tomcat 連接池,需要移除 tomcat-jdbc 依賴
- 在application.properties文件中加上spring.datasource.type=com.zaxxer.hikari.HikariDataSource
我們來看一下SpringBoot2.0怎么使用配置HikariDataSource的
下面是org.springframework.boot.autoconfigure.jdbc.DataSourceConfiguration中的相關(guān)代碼
/**
* 下面的三個注解意思是當(dāng)classpath中有HikariDataSource.class,并且Spring上下文中沒有配置DataSource的bean
* 并且spring.datasource.type的值是com.zaxxer.hikari.HikariDataSource的時候,SpringBoot自動幫我們選擇默認(rèn)的連接池是HikariDataSource
*/
@ConditionalOnClass({HikariDataSource.class})
@ConditionalOnMissingBean({DataSource.class})
@ConditionalOnProperty(name = {"spring.datasource.type"},havingValue = "com.zaxxer.hikari.HikariDataSource",matchIfMissing = true)
static class Hikari {
Hikari() {
}
@Bean
@ConfigurationProperties(prefix = "spring.datasource.hikari")
HikariDataSource dataSource(DataSourceProperties properties) {
HikariDataSource dataSource = (HikariDataSource)DataSourceConfiguration.createDataSource(properties, HikariDataSource.class);
if (StringUtils.hasText(properties.getName())) {
dataSource.setPoolName(properties.getName());
}
return dataSource;
}
}
最后看看,HikariCp配置的參數(shù)有哪些?
# 不同數(shù)據(jù)源這四個配置都會用到 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 #以下的配置項是hikari特有的配置 # 等待連接池分配連接的最大時長(毫秒),超過這個時長還沒可用的連接則發(fā)生SQLException, 默認(rèn):30秒 spring.datasource.hikari.connection-timeout=30000 # 最小連接數(shù) spring.datasource.hikari.minimum-idle=5 # 最大連接數(shù) spring.datasource.hikari.maximum-pool-size=15 # 自動提交 spring.datasource.hikari.auto-commit=true # 一個連接idle狀態(tài)的最大時長(毫秒),超時則被釋放(retired),默認(rèn):10分鐘 spring.datasource.hikari.idle-timeout=600000 # 連接池名字 spring.datasource.hikari.pool-name=DatebookHikariCP # 一個連接的生命時長(毫秒),超時而且沒被使用則被釋放(retired),默認(rèn):30分鐘 1800000ms,建議設(shè)置比數(shù)據(jù)庫超時時長少60秒 spring.datasource.hikari.max-lifetime=28740000 spring.datasource.hikari.connection-test-query=SELECT 1 #以下是針對MYSQL驅(qū)動的配置參數(shù) # 在每個連接中緩存的語句的數(shù)量。默認(rèn)值為保守值25。建議將其設(shè)置為250-500之間 spring.datasource.hikari.prepStmtCacheSize = 300 # 緩存的已準(zhǔn)備SQL語句的最大長度,默認(rèn)值是256,但是往往這個長度不夠用 spring.datasource.hikari.prepStmtCacheSqlLimit = 2048 # 緩存開關(guān),如果這里設(shè)置為false,上面兩個參數(shù)都不生效 spring.datasource.hikari.cachePrepStmts = true #較新版本的 MySQL 支持服務(wù)器端準(zhǔn)備好的語句,這可以提供實質(zhì)性的性能提升 spring.datasource.hikari.useServerPrepStmts = true
HikariCP官方地址: https://github.com/brettwooldridge/HikariCP/wiki
到此這篇關(guān)于Spring多個數(shù)據(jù)源配置詳解的文章就介紹到這了,更多相關(guān)Spring多數(shù)據(jù)源配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java數(shù)據(jù)類型轉(zhuǎn)換實例解析
這篇文章主要介紹了Java數(shù)據(jù)類型轉(zhuǎn)換實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11
Java簡單實現(xiàn)session保存到redis的方法示例
這篇文章主要介紹了Java簡單實現(xiàn)session保存到redis的方法,結(jié)合實例形式分析了Java將session存入redis緩存服務(wù)器的相關(guān)設(shè)置、實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下2018-05-05
Java中system.exit(0) 和 system.exit(1)區(qū)別
本文主要介紹了Java中system.exit(0) 和 system.exit(1)區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
Java HtmlEmail 郵件發(fā)送的簡單實現(xiàn)代碼
下面小編就為大家?guī)硪黄狫ava HtmlEmail 郵件發(fā)送的簡單實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06
在SpringBoot環(huán)境中使用Mockito進(jìn)行單元測試的示例詳解
Mockito是一個流行的Java?mocking框架,它允許開發(fā)者以簡單直觀的方式創(chuàng)建和使用模擬對象(mocks),Mockito特別適用于在Spring?Boot環(huán)境中進(jìn)行單元測試,所以本文介紹了在SpringBoot環(huán)境中使用Mockito進(jìn)行單元測試的示例,需要的朋友可以參考下2024-11-11
創(chuàng)建好SpringBoot項目后但是找不到Maven的解決方法
在使用IDEA專業(yè)版創(chuàng)建好SpringBoot項目后,發(fā)現(xiàn)上方導(dǎo)航欄的運(yùn)行按鈕是灰色的,而且左側(cè)導(dǎo)航欄的pom.xml的圖標(biāo)顏色也不是正常的,點開右側(cè)導(dǎo)航欄的Maven后,發(fā)現(xiàn)Maven找不到,所以本文介紹了創(chuàng)建好SpringBoot項目后但是找不到Maven的解決方法,需要的朋友可以參考下2024-10-10
Java實現(xiàn)的Excel列號數(shù)字與字母互相轉(zhuǎn)換功能
這篇文章主要介紹了Java實現(xiàn)的Excel列號數(shù)字與字母互相轉(zhuǎn)換功能,涉及java針對Excel相關(guān)數(shù)值與字符串操作技巧,需要的朋友可以參考下2018-03-03

