通过JedisPool资源池管理jedis连接

要应用JedisPool资源池管理jedis,需要引入两个包,(1)jedis jar包或redis jar包 (2)阿帕奇下的commons-pool jar包,好像用到资源池的都需要这个

下面是一点点小代码。需要说明的是,释放jedis资源的方法已经deprecated了,不知道是不是这个原因,导致释放的jedis资源能继续使用。具体原因等确定后再更新。

package jedis.redis;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class UseJedisPool {

    private static JedisPool jedisPool = null;

    //初始化redis连接池
    static{
        JedisPoolConfig config = new JedisPoolConfig();
        //配置最大jedis实例数
        config.setMaxTotal(1000);
        //配置资源池最大闲置数
        config.setMaxIdle(200);
        //等待可用连接的最大时间
        config.setMaxWaitMillis(10000);
        //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的
        config.setTestOnBorrow(true);
        jedisPool = new JedisPool("10.133.17.79",6379);
    }

    //获取Jedis实例
    public synchronized static Jedis getJedis(){
        if(jedisPool != null){
            Jedis resource = jedisPool.getResource();
            return resource;
        }else{
            return null;
        }
    }

    //释放Jedis资源
    public static void returnResource(final Jedis jedis){
        if(jedis != null){
            jedisPool.returnResource(jedis);
        }
    }


    public static void main(String[] args){
        Jedis jedis = UseJedisPool.getJedis();
        jedis.set("test", "hello JedisPool.");
        jedis.set("hello", "JedisPool.");
        System.out.println(jedis.get("test"));
        UseJedisPool.returnResource(jedis);
        //测试发现释放Jedis资源后,下面的这个还能返回JedisPool  ????
        System.out.println(jedis.get("hello"));
    }
}

自Jedis3.0版本后jedisPool.returnResource()遭弃用,官方重写了Jedis的close方法用以代替;官方建议应用redis.clients.jedis#Jedis的close方法进行资源回收,官方代码如下:

@Override
public void close() {
  if (dataSource != null) {
    if (client.isBroken()) {
      this.dataSource.returnBrokenResource(this);
    } else {
      this.dataSource.returnResource(this);
    }
  } else {
    client.close();
  }
}

也就是说在使用完jedis的时候,我们需要手动去关闭。

你可能感兴趣的:(redis)