要应用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的时候,我们需要手动去关闭。