这个问题涉及的方面很多,需要一步步去排查,可能环境有问题,数据库有问题,但是网上最多的应该是如下的方式去解决。
以单个数据源为主,多个数据源基本方法一致。
1、MySQL 5版本之前可以通过在URL后面加入autoReconnect=true,如:
spring.datasource.url=jdbc:mysql://localhost/test?autoReconnect=true
2、application.properties文件中加入:
spring.datasource.test-on-borrow=true #(即在获取Connection对象时检测其可用性),不过这样会影响性能,但是这个配置是最有效的。
spring.datasource.test-while-idle=true
spring.datasource.time-between-eviction-runs-millis= 3600000
3、粗暴点的直接修改wait_timeout时间:
show global variables like 'wait_timeout';
推荐使用第2种,从配置项入手。
网上有这块的详细解释:
datasource.qss.max-idle=10
# Number of ms to wait bef