數據源(HikariCP)


HikariCP 是一個高性能的 JDBC 連接池組件。下圖是性能的比較測試結果:

自從看到了這張圖,我就對於我之前一直在使用了 c3p0 產生了深深的懷疑,迫切的期望得到對應的數據來優化我的代碼。

 

=====================================

============ 連接池比對 ============
=====================================

proxool 更新時間截止2008年。速度可以,穩定性稍差,發較高的情況下會出錯。

c3p0 太古老,代碼及其復雜,不利於維護。貌似都比它強。

dbcp 是 apache 上的一個 java 連接池項目,也是 tomcat 使用的連接池組件。

druid 功能比較全面,且擴展性較好,比較方便對jdbc接口進行監控跟蹤等。

BoneCP 13年前最快的連接池項目。2013年后不再更新,心灰意冷。

HikariCP 光連接池

 

HikariCP 與 Spring的結合

<!-- Hikari Datasource -->  
<bean id="dataSourceHikari" class="com.zaxxer.hikari.HikariDataSource"  destroy-method="shutdown">  
 <!-- <property name="driverClassName" value="${db.driverClass}" /> --> <!-- 無需指定,除非系統無法自動識別 -->  
 <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8" />  
 <property name="username" value="${db.username}" />  
 <property name="password" value="${db.password}" />  
  <!-- 連接只讀數據庫時配置為true, 保證安全 -->  
 <property name="readOnly" value="false" />  
 <!-- 等待連接池分配連接的最大時長(毫秒),超過這個時長還沒可用的連接則發生SQLException, 缺省:30秒 -->  
 <property name="connectionTimeout" value="30000" />  
 <!-- 一個連接idle狀態的最大時長(毫秒),超時則被釋放(retired),缺省:10分鍾 -->  
 <property name="idleTimeout" value="600000" />  
 <!-- 一個連接的生命時長(毫秒),超時而且沒被使用則被釋放(retired),缺省:30分鍾,建議設置比數據庫超時時長少30秒,參考MySQL wait_timeout參數(show variables like '%timeout%';) -->  
 <property name="maxLifetime" value="1800000" />  
 <!-- 連接池中允許的最大連接數。缺省值:10;推薦的公式:((core_count * 2) + effective_spindle_count) -->  
 <property name="maximumPoolSize" value="15" />  
</bean>

  

<bean id = "dataSource" class="com.zaxxer.hikari.HikariDataSource" destroy-method="close">  
        <property name="driverClassName" value="${jdbc.driverClassName}" />  
        <property name="jdbcUrl" value="${jdbc.url}" />  
        <property name="username" value="${jdbc.username}" />  
        <property name="password" value="${jdbc.password}" />  
        <property name="maximumPoolSize" value="100" />  
        <property name="minimumIdle" value="10" />  
        <property name="connectionTestQuery" value="select 1" />  
        <property name="dataSourceProperties">  
            <props>  
                <prop key="cachePrepStmts">true</prop>  
                <prop key="prepStmtCacheSize">250</prop>  
                <prop key="prepStmtCacheSqlLimit">2048</prop>  
                <prop key="useServerPrepStmts">true</prop>  
            </props>  
        </property>  
    </bean> 

 

1 下載地址

http://mvnrepository.com/artifact/com.zaxxer/HikariCP

2 Git主頁

https://github.com/brettwooldridge/HikariCP

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM