Jedis异常:NoSuchElementException: Timeout waiting for idle object
出现异常:java.util.NoSuchElementException: Timeout waiting for idle object
出现原因是:不应该在try中释放资源,而应该在finally中处理。在try中释放资源,每当出现一次异常将会导致一个jedis对象无法释放,pool池中可用的jedis对象资源会越来越少。终于将会导致java.util.NoSuchElementException: Timeout waiting for idle object。
这样的问题是一个慢性问题,需要时间积累才会出现。因为请求无法获取空暇对象,页面会出现服务端500错误。
try{
jedis = pool.getResource();
// xxx 业务代码
// 原来代码:pool.returnResource(jedis);
// 应该放在finally块中,否则每次发生异常将导致一个jedis对象没有被移除
}catch(RuntimeException e){
if(jedis != null ) {
// 获取连接失败时,应该返回给pool,否则每次发生异常将导致一个jedis对象没有被回收
pool.returnBrokenResource(jedis);
}
}finally{
// 正确释放资源
if(jedis != null ) {
pool.returnResource(jedis);
}
}
浙公网安备 33010602011771号