记一次redis获取不到连接池,Timeout waiting for idle object

最近出现一比较诡异问题,源码相同的情况下,线上和线下运行效果不一致。

简单介绍下环境:springboot , apollo,发版编译jenkins;

现象是开发环境正常运行,线上启动

Caused by: java.util.NoSuchElementException: Timeout waiting for idle object
	at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:449) ~[commons-pool2-2.4.2.jar!/:2.4.2]
	at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:363) ~[commons-pool2-2.4.2.jar!/:2.4.2]
	at redis.clients.util.Pool.getResource(Pool.java:49) ~[jedis-2.9.0.jar!/:na]
	... 37 common frames omitted

翻看源码,发现有些coding很欠妥;

大概的逻辑是静态代码块-》静态方法-》静态初始化redis连接-》redis连接参数通过spring的postconstruct 获取;

经过增加日志输出:发现静态代码块执行时,redis的连接参数并未获取到,抛出上述异常后,日志中输出连接参数为null;

奇怪的时线下打包运行ok,bc比对完全相同。

问题猜测,静态初始化过程与spring bean 初始化存在先后顺序问题,bd找的问题解决方式都是扩大连接数,或jar包不匹配。都不是现状的问题。

调整策略:

静态初始化区,采用postconstruct,交给spring管理,同时增加dependon注解。

总结:coding对于静态的使用要慎重,若是使用spring 搭建整体项目,尽量交由spring 管理bean 的初始化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值