package com.star.util;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import com.star.client.RedisClient;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
public class RedisUtil {
// 日志记录
private static final Log log = LogFactory.getLog(RedisClient.class);
// redis连接池
private JedisPool pool;
// Redis服务器IP
private static String ADDR = "127.0.0.1";
// Redis的端口号
private static int PORT = 6379;
// 访问密码
//private static String AUTH = "871185723";
// 可用连接实例的最大数目,默认值为8;
// 如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
private static int MAX_ACTIVE = 1024;
// 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
private static int MAX_IDLE = 25;
// 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
private static int MAX_WAIT = 10000;
private static int TIMEOUT = 100000;
// 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
private static boolean TEST_ON_BORROW = false;
// 获取jedis
public Jedis getResource() {
//Jedispool属性设置
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxWaitMillis(MAX_WAIT);
config.setMaxIdle(MAX_IDLE);
config.setMaxTotal(MAX_ACTIVE);
config.setTestOnBorrow(TEST_ON_BORROW);
//生成jedispool
pool = new JedisPool(config,ADDR,PORT,TIMEOUT);
Jedis jedis = pool.getResource();
if (jedis.equals(null)) {
System.out.println("从RedisPool中获取jedis失败");
return null;
}
return jedis;
}
// 关闭连接
public void close(Jedis jedis) {
jedis.disconnect();
}
// 无法返还redispool,释放redis对象
@SuppressWarnings("deprecation")
public void brokensource(Jedis jedis) {
if (jedis != null) {
try {
pool.returnBrokenResource(jedis);
} catch (Exception e) {
System.out.println("释放jedis对象失败");
}
}
}
}
评论0
最新资源