Джедаи: Не удалось получить ресурс из пула.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Джедаи: Не удалось получить ресурс из пула.

Сообщение Anonymous »

Справочная информация

Наше приложение использует Jedis-2.2.1 и подключается к Redis-2.6, вот как я получаю ресурс jedis:

protected static JedisWrapper getRedisUserWrite(String UDID) {
if (redisUserWritePools.get(0) == null) init();

int hash = hash(UDID);
Jedis jedis = redisUserWritePools.get(hash).getResource();
jedis.select(dbs.get("redisUserWritePools" + hash));

return new JedisWrapper(jedis, redisUserWritePools.get(hash));
}


А это мой JedisWrapper(Унифицирует управление ресурсами):

public class JedisWrapper {
private Jedis jedis;
private JedisPool pool;

public JedisWrapper(Jedis jedis, JedisPool pool) {
this.jedis = jedis;
this.pool = pool;
}

public Jedis get(){
return this.jedis;
}

public void returnResource() {
if(null != this.jedis){
this.pool.returnResource(this.jedis);
}
}

public void returnBrokenResource() {
if(null != this.jedis) {
this.pool.returnBrokenResource(this.jedis);
}
this.jedis = null;
}
}


JedisWrapper — это контейнер экземпляра Jedis, вот как я его использую:

private static void cacheSDKIDs(String UDID, String[] SDKIDs) {

JedisWrapper wrapper = getRedisUserWrite(UDID);
try {
if (SDKIDs != null) {
wrapper.get().del(UDID);
wrapper.get().sadd(UDID, SDKIDs);
}
} catch (JedisConnectionException e) {
e.printStackTrace();
wrapper.returnBrokenResource();
}catch (Exception e) {
e.printStackTrace();
} finally {
wrapper.returnResource();
}
}


Обратите внимание, что SKDID может быть очень большим (например, может достигать максимального размера в 8 КБ).

Вот в чем проблема

Каждый раз, когда я перезапускаю наше приложение, все соединения Redis работают нормально, но несколько часов
спустя возникает исключение «Не удалось получить ресурс из пула».. И частота становится все выше и выше, затем все соединения с Redis отключаются и можно создать новое соединение.

Вот моя конфигурация:











Трассировка стека исключений:

Caused by: redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool
at redis.clients.util.Pool.getResource(Pool.java:40)
at com.xxxice.redis.BaseRedis.getRedisUserWrite(BaseRedis.java:158)
at com.xxx.service.redis.DeviceRedis.cacheSDKIds(DeviceRedis.java:128)
at com.xxx.redis.DeviceRedis.cacheDevice(DeviceRedis.java:65)
at com.xxx.service.DeviceService.update(DeviceService.java:88)
at com.xxx.controller.Devices.update(Devices.java:25)
... 32 more
Caused by: java.util.NoSuchElementException: Timeout waiting for idle object
at org.apache.commons.pool.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:1174)
at redis.clients.util.Pool.getResource(Pool.java:38)
... 37 more


Подробнее здесь: https://stackoverflow.com/questions/232 ... m-the-pool
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»