首頁 > 軟體

springboot2中HikariCP連線池的相關設定問題

2022-12-23 14:01:03

springboot2 HikariCP連線池相關設定

專案中使用了springboot2.1.4作為框架,資料庫連結池選用了號稱非常快的也是springboot預設支援的HikariCP作為連線池。

引入springboot完全支援,所以不需要引入額外的jar,組態檔如下:

spring:
  application:
    name: framework-manage
  profiles:
    active: dev
  #資料庫連線
  datasource:
    url: jdbc:mysql://localhost:3306/rz_test?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=CTT
    username: root
    password: root
    #連線池
    hikari:
      minimum-idle: 5
      maximum-pool-size: 15
      auto-commit: true
      idle-timeout: 30000
      pool-name: DatebookHikariCP
      max-lifetime: 120000
      connection-timeout: 30000
      connection-test-query: SELECT 1

在剛開始設定時候,將max-lifetime設定為1800000(網上很多部落格設定均為這個),隔上一段時間不連線,就會出現以下警告,需要等待四五個這種警告後,才能請求回資料。

DatebookHikariCP - Failed to validate connection
com.mysql.cj.jdbc.ConnectionImpl@23338be2 (No operations allowed after connection closed.)
. Possibly consider using a shorter maxLifetime value.

修改過資料庫的相關設定,還是不行,後來翻譯了下這段話,發現是說可能考慮使用較短的maxLifetime值,這個值最小是30000,於是將其修改為30000後,又出現了下面這個警告:

DatebookHikariCP - idleTimeout is close to or more than maxLifetime, disabling it.

這個只是在啟動時候出現,並不影響操作,後來查詢發現,設定idleTimeout 時候有一個規則,即如果idleTimeout+1秒>maxLifetime 且 maxLifetime>0,則會被重置為0(代表永遠不會退出);如果idleTimeout!=0且小於10秒,則會被重置為10秒。

於是將max-lifetime設定為了120000,這個問題不在出現。

HikariCP常用的引數設定

1.autoCommit

自動提交從池中返回的連線,預設為true。

2.connectionTimeout

等待來自池的連線的最大毫秒數,預設為30000,如果小於250毫秒,則被重置回30秒。

3.idleTimeout

連線允許在池中閒置的最長時間,預設為600000,即10分鐘。

如果idleTimeout+1秒>maxLifetime 且 maxLifetime>0,則會被重置為0(代表永遠不會退出);如果idleTimeout!=0且小於10秒,則會被重置為10秒。

只有當minimumIdle小於maximumPoolSize時,這個引數才生效,當空閒連線數超過minimumIdle,而且空閒時間超過idleTimeout,則會被移除。

4.maxLifetime

池中連線最長生命週期。預設為1800000,如果不等於0且小於30秒則會被重置回30分鐘。

5.minimumIdle

控制連線池空閒連線的最小數量,當連線池空閒連線少於minimumIdle,而且總共連線數不大於maximumPoolSize時,HikariCP會盡力補充新的連線。

為了效能考慮,不建議設定此值,而是讓HikariCP把連線池當做固定大小的處理,預設minimumIdle與maximumPoolSize一樣。

當minIdle<0或者minIdle>maxPoolSize,則被重置為maxPoolSize,該值預設為10。

6.maximumPoolSize

池中最大連線數,包括閒置和使用中的連線。

預設為10。

如果maxPoolSize小於1,則會被重置。

當minIdle<=0被重置為DEFAULT_POOL_SIZE則為10;如果minIdle>0則重置為minIdle的值。

7.poolName

連線池的使用者定義名稱,主要出現在紀錄檔記錄和JMX管理控制檯中以識別池和池設定。

預設為HikariPool-1。

8.readOnly

從池中獲取的連線是否預設處於唯讀模式。

預設為false。

9.connection-test-query

如果您的驅動程式支援JDBC4,我們強烈建議您不要設定此屬性。

這是針對不支援JDBC4的“傳統”驅動程式Connection.isValid() API。

這是在連線從池中獲得連線以確認與資料庫的連線仍然存在之前將要執行的查詢。

再一次,嘗試執行沒有此屬性的池,如果您的驅動程式不符合JDBC4的要求,HikariCP將記錄一個錯誤以告知您。

預設值:無

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com