Springboot数据库连接池报错SocketTimeoutException:
来源:互联网 发布:闺蜜 礼物 知乎 编辑:程序博客网 时间:2024/06/14 00:51
Springboot数据库连接池报错SocketTimeoutException:
java.net.SocketException: Broken pipe
移除点击此处添加图片说明文字
发现服务一般过一段时间会报错。
移除点击此处添加图片说明文字注意这个报错:
移除点击此处添加图片说明文字可以看到Read timed out
这个异常通常在Linux服务器上会发生,原因是Linux系统会主动断开一个长时间没有通信的连接
那么我们的问题就是:数据库连接池长时间处于间歇状态,导致Linux系统将其断开了,然后抛出了这个错误。
要想解决这个问题,就要主动让我们的连接池保持连接,不被断开。处理方式很简单,只需要加入相关配置即可。
打开
application.properties
文件,加入下面配置:
spring.datasource.testOnBorrow=truespring.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
- Apache Derby (via daiscog)
SELECT 1 FROM SYSIBM.SYSDUMMY1
- DB2
select count(*) from systables
发现服务一般过一段时间会报错。
移除点击此处添加图片说明文字注意这个报错:
移除点击此处添加图片说明文字可以看到Read timed out
这个异常通常在Linux服务器上会发生,原因是Linux系统会主动断开一个长时间没有通信的连接
那么我们的问题就是:数据库连接池长时间处于间歇状态,导致Linux系统将其断开了,然后抛出了这个错误。
要想解决这个问题,就要主动让我们的连接池保持连接,不被断开。处理方式很简单,只需要加入相关配置即可。
打开
application.properties
文件,加入下面配置:
<code class="stylus" style="box-sizing: border-box; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px; color: rgb(101, 123, 131); background-color: transparent; border-radius: 0px; padding: 0px; white-space: pre; border: none;">spring<span class="hljs-selector-class" style="box-sizing: border-box;">.datasource</span><span class="hljs-selector-class" style="box-sizing: border-box;">.testOnBorrow</span>=true spring<span class="hljs-selector-class" style="box-sizing: border-box;">.datasource</span><span class="hljs-selector-class" style="box-sizing: border-box;">.validationQuery</span>=SELECT <span class="hljs-number" style="box-sizing: border-box; color: rgb(42, 161, 152);">1</span></code>
第一句的意思是:自动重连
第二句的意思是:验证连接的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
- Apache Derby (via daiscog)
SELECT 1 FROM SYSIBM.SYSDUMMY1
- DB2
select count(*) from systables
- Springboot数据库连接池报错SocketTimeoutException:
- SocketTimeoutException
- SpringBoot切换数据库连接池
- springboot数据库连接池使用策略
- SpringBoot之数据库连接池(druid)
- SpringBoot中配置orcale数据库连接
- SpringBoot整合HikariCP数据库连接池
- SpringBoot整合druid数据库连接池
- springBoot数据库连接池常用配置
- SpringBoot项目创建与数据库连接
- springboot整合druid数据库连接池
- springboot-data-jpa默认数据库连接池
- SpringBoot初始教程之数据库连接池(druid)
- SpringBoot中配置使用Druid数据库连接池
- springboot 使用c3p0数据库连接池的方法
- 数据库连接断开,数据库连接池报错问题
- SpringBoot初始教程之数据库连接池(druid)(六)
- mysql数据库连接超过8小时失效的解决方案(springboot)
- JS原型与原型链详解
- 移动 APP 自动化测试框架对比
- 使用ffmpeg推送视频流至流媒体服务器(c语言)
- 棋盘问题
- hdu 2243 AC自动机+dp(矩阵快速幂优化)
- Springboot数据库连接池报错SocketTimeoutException:
- 线性回归,最小二乘法
- service activemq does not support chkconfig
- gdf
- JAVAWEB开发之redis学习(七)——key相关的通用操作
- jquery 如何获取鼠标当前位置?
- Oracle查询库中的所有表,表的字段等等操作
- python学习3——列表
- k8s内容器不可访问