springboot假死、连接泄漏
springboot版本:2.1.4.RELEASE
默认自带redis版本:2.9.1
服务在注册中心还是up状态
jstack有大量waiting线程
- parking to wait for,等待锁定同一个地址的线程和线程池最大配置一样
https://www.cnblogs.com/uncleyong/p/11136396.html
package redis.clients.jedis;下的JedisPool
public Jedis getResource() {
Jedis jedis = (Jedis)super.getResource(); // 这里与close互相影响,造成线程不安全
jedis.setDataSource(this);
return jedis;
}
package redis.clients.jedis;下的Jedis
@Override
public void close() {
if (dataSource != null) {
if (client.isBroken()) { // 判断redis是否可以连接
this.dataSource.returnBrokenResource(this);
} else {
this.dataSource.returnResource(this); // 归还redis连接
}
this.dataSource = null; // 置为null;执行这行前,连接可能被其它线程借走
} else {
super.close();
}
}
修改方案:
https://github.com/redis/jedis/pull/1918/commits/df1bffa3c77f4ede4c912f2c3e78b5c8857725e7

__EOF__
本文作者:持之以恒(韧)
关于博主:擅长性能、全链路、自动化、企业级自动化持续集成(DevTestOps)、测开等
面试必备:项目实战(性能、自动化)、简历笔试,https://www.cnblogs.com/uncleyong/p/15777706.html
测试提升:从测试小白到高级测试修炼之路,https://www.cnblogs.com/uncleyong/p/10530261.html
欢迎分享:如果您觉得文章对您有帮助,欢迎转载、分享,也可以点击文章右下角【推荐】一下!
关于博主:擅长性能、全链路、自动化、企业级自动化持续集成(DevTestOps)、测开等
面试必备:项目实战(性能、自动化)、简历笔试,https://www.cnblogs.com/uncleyong/p/15777706.html
测试提升:从测试小白到高级测试修炼之路,https://www.cnblogs.com/uncleyong/p/10530261.html
欢迎分享:如果您觉得文章对您有帮助,欢迎转载、分享,也可以点击文章右下角【推荐】一下!

浙公网安备 33010602011771号