Springboot数据库连接池报错SocketTimeoutException:

Springboot数据库连接池报错SocketTimeoutException:

java.net.SocketException: Broken pipe



 Springboot数据库连接池报错SocketTimeoutException:_第1张图片移除点击此处添加图片说明文字

​发现服务一般过一段时间会报错。​

  Springboot数据库连接池报错SocketTimeoutException:_第2张图片移除点击此处添加图片说明文字

​注意这个报错:

  Springboot数据库连接池报错SocketTimeoutException:_第3张图片移除点击此处添加图片说明文字

可以看到​Read timed out 

这个异常通常在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


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:_第4张图片移除点击此处添加图片说明文字

​发现服务一般过一段时间会报错。​

  Springboot数据库连接池报错SocketTimeoutException:_第5张图片移除点击此处添加图片说明文字

​注意这个报错:

  Springboot数据库连接池报错SocketTimeoutException:_第6张图片移除点击此处添加图片说明文字

可以看到​Read timed out 

这个异常通常在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


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

你可能感兴趣的:(大数据,Java)