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