一、问题:java.util.NoSuchElementException: Timeout waiting for idle object
二、原因:
获取连接出错时应该调用returnBrokenResource,否则每当出现一次异常将会导致一个jedis对象无法释放,pool池中可用的jedis对象资源会越来越少,最终将会导致java.util.NoSuchElementException: Timeout waiting for idle object。这种问题是一个慢性问题,需要时间积累才会发作。而定时任务每晚会大量查询redis,因此加快了该进程。
三、解决办法:
获取连接失败时,调用returnBrokenResource方法。
try {
jedis = pool.getResource();
} catch (RuntimeException e) {
if(jedis != null ) {
pool.returnBrokenResource(jedis);//获取连接失败时,应该返回给pool,否则每次发生异常将导致一个jedis对象没有被回收。
}
}
原文:https://blog.csdn.net/gfw589/article/details/53674087/