jedis.close问题

使用jedis客户端2.8.1 建立JedisClient,代码如下
 
    private final static String host = "xxxx";
    private final static int port = 1231;
    public static JedisPool jedisPool;


    public static Jedis getJedis() {
        if (jedisPool == null) {
            JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
            jedisPoolConfig.setMaxIdle(5);
            jedisPoolConfig.setMaxTotal(5);
            jedisPool = new JedisPool(jedisPoolConfig,host, port);

        }
        return jedisPool.getResource();
    }

    public static void closeJedis(Jedis jedis) {
        if (jedis != null) {
          jedis.close();
        }

    }


测试时发现,即使执行jedis.close后,后面同一个jedis实例还能使用,代码如下,
Jedis jedis = JedisClient.getJedis();
jedis.type("default-item:82");
jedis.close();
jedis.type("default-item:89");

上面 jedis.close执行后,为什么下面的jedis还能使用,不是被释放了吗?请大牛指点


补充下:
JedisClient设置了最大连接数为5,运行如下代码
for(int i=0;i<10;i++){
                 Jedis jedis = JedisClient.getJedis();
                 jedis.type("default-item:82");
                 System.out.println("第"+i+"个连接");
                // jedis.close();
}


如果注释掉关闭操作,因为开了10个jedis连接,到第五个就会阻塞一直到超时报错,加上就正常运行,说明jedis.close确实回收了,但不明白为什么在jedis.close后,此jedis还能用

猜你喜欢

转载自yinyonggen.iteye.com/blog/2300619