Springboot數據庫連接池報錯的解決辦法


Springboot數據庫連接池報錯的解決辦法

這個異常通常在Linux服務器上會發生,原因是Linux系統會主動斷開一個長時間沒有通信的連接

那么我們的問題就是:數據庫連接池長時間處於間歇狀態,導致Linux系統將其斷開了,然后拋出了這個錯誤。

要想解決這個問題,就要主動讓我們的連接池保持連接,不被斷開。處理方式很簡單,只需要加入相關配置即可。

打開application.properties文件,加入下面配置:

spring.datasource.testOnBorrow=true spring.datasource.validationQuery=SELECT 1

第一句的意思是:自動重連
第二句的意思是:驗證連接的sql語句

關於validationQuery

SELECT 1並不是對所有的數據庫都通用,這個得按照實際情況,下面有一個建議:

SELECT 1

  • H2
  • MySQL
  • Microsoft SQL Server (according to NimChimpsky)
  • PostgreSQL
  • SQLite

SELECT 1 FROM DUAL

  • Oracle

SELECT 1 FROM any_existing_table WHERE 1=0
or
SELECT 1 FROM INFORMATION_SCHEMA.SYSTEM_USERS

  • HSQLDB (tested with version 1.8.0.10)

VALUES 1
or
SELECT 1 FROM SYSIBM.SYSDUMMY1


SELECT 1 FROM SYSIBM.SYSDUMMY1

  • DB2

select count(*) from systables

  • Informix

原文出自:http://www.jianshu.com/p/7a45819d6cda


免責聲明!

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



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