徐州做企业网站,西安城乡住房建设厅网站首页,网络工程专业学什么课程,网站建设houxiaoer上一篇文章我们讲了如何配置多数据源#xff0c;但是配置在使用一段时间之后#xff0c;查询数据库会发生报错#xff1a;No operations allowed after connection closed。
一、问题原因#xff1a; 经过排查发现是因为MySQL5.0以后针对超长时间DB连接做了一个处理#…上一篇文章我们讲了如何配置多数据源但是配置在使用一段时间之后查询数据库会发生报错No operations allowed after connection closed。
一、问题原因 经过排查发现是因为MySQL5.0以后针对超长时间DB连接做了一个处理那就是如果一个DB连接在无任何操作情况下过了8个小时后(Mysql 服务器默认的“wait_timeout”是8小时)Mysql会自动把这个连接关闭。这就是问题的所在在连接池中的connections如果空闲超过8小时mysql将其断开而连接池自己并不知道该connection已经失效如果这时有 Client请求connection连接池将该失效的Connection提供给Client将会造成上面的异常。 所以配置datasource时需要配置相应的连接池参数定是去检查连接的有效性定时清理无效的连接。 二、配置文件修改
#指定连接池最大的空闲连接数量.
spring.datasource.max-idle10
#指定连接池等待连接返回的最大等待时间毫秒单位.
spring.datasource.max-wait10000
#指定必须保持连接的最小值(For DBCP and Tomcat connection pools)
spring.datasource.min-idle5
#指定启动连接池时初始建立的连接数量
spring.datasource.initial-size5
#指定获取连接时连接校验的sql查询语句.
spring.datasource.validation-querySELECT 1
#获取连接时候验证会影响性能
spring.datasource.test-on-borrowfalse
#当连接空闲时是否执行连接测试.
spring.datasource.test-while-idletrue
#指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔
spring.datasource.time-between-eviction-runs-millis18800
新增上面的配置之后就不再出现数据库连接超时关闭的问题了。