资讯

展开

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

作者:快盘下载 人气:

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

慢接口告警分析

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>

加载全部内容

相关教程
猜你喜欢
用户评论
快盘暂不提供评论功能!