Jedis : impossible d'obtenir une ressource de la piscine
Fond
Notre application utilise Jedis-2.2.1
et se connecte à Redis-2.6
, voici comment j'obtiens des jedis ressource :
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));
}
Et c'est mon JedisWrapper
(Unifier la gestion des ressources):
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
est le conteneur si Jedis exemple, voici comment je l'utilise :
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();
}
}
Noter que, SKDIDs
peut-être très large(par exemple, pourraient atteindre le maximum de 8KO).
Voici le problème
À chaque fois que je le redémarrage de notre application, tous redis connexions sont normaux, mais plusieurs heures
plus tard, le Could not get a resource from the pool
Exception. Et la fréquence de devenir de plus en plus haut, puis toutes les connexions à Redis sont déconnectés et peut créer une nouvelle connexion.
Voici ma configuration :
<bean id = "redisConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxActive" value="400" />
<property name="maxIdle" value="100" />
<property name="minIdle" value="20" />
<property name="maxWait" value="4000" />
<property name="testOnBorrow" value="true"/>
<property name="testOnReturn" value="true" />
</bean>
Exception Stacktrace:
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
est-il résolu ? je suis confronté problème similaire
est-ce seulement le lieu qui à l'aide de JedisWrapper?
OriginalL'auteur MrROY | 2014-04-23
Vous devez vous connecter pour publier un commentaire.
Dans votre JedisWrapper, les Jedis est créé comme une variable de classe qui est instanciée une fois. Merci de nous l'indiquer à l'intérieur de l'méthodes getJedis, alors le problème sera résolu
OriginalL'auteur Remya
de vérifier si vous avez la permission d'accéder redis à l'aide de code
OriginalL'auteur samith kumarasingha