现象:
接口请求,10秒钟超时,看了一下,是sql查询耗时太长了,数据还没来得及返回,连接就断开了。
连接断开,上层应用直接报错。。
这些问题,都是。。。知道答案后,就觉得,emmm,好简单。知道答案前,…tmd, 这啥玩意儿。。。。
直接说答案吧:
数据库连接超时,那就配置超时时长,准确地说是 druid 的超时时长。。。
要设置 druid 的 connectTimeout 、socketTimeout 这两个配置项,
嗯。单这样说,有点。。。
一份druid 配置
druid:
url: jdbc:mysql://10.12.1.9:3306/student?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
username: username
password: passwordxxxx
useSSL: false
initial-size: 50
min-idle: 50
max-active: 200
connectTimeout: 600000 #1.2.12版本需要单独配置才生效
socketTimeout: 600000 #1.2.12版本需要单独配置才生效
有了配置,不够,需要在代码里面解析配置
于是要写一个:
DruidProperties.java
import org.springframework.boot.context.properties.ConfigurationProperties;
/**
* druid
*/
@ConfigurationProperties(prefix = "druid")
public class DruidProperties {
private String url;
private String username;
private S

文章讲述了在SpringBoot项目中,遇到接口请求超时的问题,经排查发现是由于SQL查询耗时过长导致的数据库连接断开。作者分享了解决方案,即配置Druid的connectTimeout和socketTimeout,并给出了相应的代码示例和配置文件的注意事项。
最低0.47元/天 解锁文章
4186

被折叠的 条评论
为什么被折叠?



