你的数据库连接池配置真的生效了吗

最近在排查一个老系统的慢接口时,发现了一个问题。就是前人对数据库连接池的配置,根本没有生效,导致数据库连接池使用的是默认配置,在流量较高的时间,就会因为获取连接时,产生竞争,导致链路超时。下面是排查和解决过程

慢接口告警分析

13.40
在这里插入图片描述

从链路中发现,getConnection耗时较长

在这里插入图片描述

数据库连接池情况,发现有等待连接的情况出现,可能是连接数较少
在这里插入图片描述

原因分析

从数据库连接池监控情况及链路慢节点分析,怀疑是因为连接池连接数较少,产生了竞争,导致较多的链路在getConnection节点等待时间较长

查看apollo配置
在这里插入图片描述

发现,最大活跃数配置的是30,最小空闲数配置的是2,可是根据连接池监控对比看,发现可能是配置的没有生效

当前使用的都是Druid的默认配置,参考https://github.com/alibaba/druid/wiki/DruidDataSource%E9%85%8D%E7%BD%AE%E5%B1%9E%E6%80%A7%E5%88%97%E8%A1%A8

为什么配置没生效呢???
查看项目源码发现原来是maven依赖的是druid包,而不是druid-spring-boot-starter

没有自动读取spring.datasource.druid配置的能力
starter包里,是通过类DruidDataSourceWrapper完成spring.datasource.druid属性的配置的

解决方案

依赖中增加druid-spring-boot-starter包依赖

		<dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.24</version>
        </dependency>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lanicc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值