线上定时任务每隔一段时间就会出现: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对象没有被回收。
}
}