我在执行redis的操作的时候,发现pool.getResource()方法卡死,代码如下:
public boolean sismember(String key, String value) {
Jedis jedis = null;
try {
jedis = pool.getResource(); //这里卡死
if(jedis != null && isRedisAlive()) {
return jedis.sismember(key, value);
}
}catch(Exception e) {
if(jedis != null) {
pool.returnBrokenResource(jedis);
}
logger.error("pic Redis sismember error, ip = " + serverIP + " , port = " + port, e);
}finally {
if(jedis != null) {
pool.returnResource(jedis);
}
}
return false;
}
下面是我创建JedisPool对象代码
JedisPoolConfig config = new JedisPoolConfig();
this.serverIP = serverIp;
this.port = port;
this.timeout = timeout;
this.auth = auth;
pool = new JedisPool(config, serverIp, port, timeout, auth);
卡死应该是资源不够,资源队列为空,导致getResource的时候阻塞住了,
所以我添加了如下配置:
config.setMaxWaitMillis(10 * 1000);
config.setMaxIdle(1000);
config.setTestOnBorrow(true);
然后成功获取到了资源。