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
欢迎分享:如果您觉得文章对您有帮助,欢迎转载、分享,也可以点击文章右下角【推荐】一下!