Spring Boot 資料庫連線逾時問題
問題摘要
問題摘要
使用Spring>使用程式Data JPA 和Hibernate with MySQL 可能會遇到連線逾時錯誤。具體來說,錯誤訊息「CommunicationsException:從伺服器成功接收的最後一個封包是>4
可能的解決方案使用autoReconnect
使用spring.datasource.testonborrow=true 和spring.datasource.validationQuery=SELECT 1 是一個可行的解決方案,不推薦。更好的方法是適當配置連接池。
- 建議解決方案:連線池配置
spring.datasource.max-active=10
- 這指定池中允許的最大並發連線數。
- 設置初始和空閒連接限制:
-
- spring.datasource.initial-size=5
- 這設定池中的初始連線數。
- spring.datasource。 max-idle=5
- 這設定了最大空閒連接數pool.
spring.datasource.min-idle=1
- 這設定池中空閒連接的最小數量。
- 啟用連線驗證:
-
- spring.datasource.test-while-idle=true
- spring.datasource.test-while-idle=true
- spring.datasource.test-while-idle=true >這會在連線空閒時驗證連線。
- spring.datasource.test -on-borrow=true
這會在從pool.
- spring.datasource.validation-query=SELECT 1
這設定要執行的驗證查詢。
-
- 設定有效期限與空閒逾時:
-
- spring.datasource.time-times-eviction-runs-milertion 5000
這指定運行驗證的頻率query。
spring.datasource.min-evictable-idle-time-millis=60000
這設定了空閒連接被視為可逐出之前的最長壽命。 透過這種方式配置連接池,定期驗證連接,清除空閒連接定期進行,並在必要時獲得新的連接。 Spring Boot 會自動處理重新連線過程,確保連線始終可用。
以上是Spring Boot資料庫連線逾時:如何有效設定連線池?的詳細內容。更多資訊請關注PHP中文網其他相關文章!