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
orSELECT 1 FROM INFORMATION_SCHEMA.SYSTEM_USERS
- HSQLDB (tested with version 1.8.0.10)
VALUES 1
orSELECT 1 FROM SYSIBM.SYSDUMMY1
- Apache Derby (via daiscog)
SELECT 1 FROM SYSIBM.SYSDUMMY1
- DB2
select count(*) from systables
- Informix
原文出自:http://www.jianshu.com/p/7a45819d6cda