java对Redis 封装
最近公司用到redis , 参考了一些帖子以及github上的代码 ,自己整理出的一些简单的封装,如果有更好的想法,希望大家互相交流,谢谢!
源文件目录有redis.properties 文件
#最大分配的对象数
redis.pool.maxTotal=1024
#最大能够保持idel状态的对象数
redis.pool.maxIdle=200
#当池内没有返回对象时,最大等待时间
redis.pool.maxWaitMillis=1000
#当调用borrow Object方法时,是否进行有效性检查
redis.pool.testOnBorrow=true
#当调用return Object方法时,是否进行有效性检查
redis.pool.testOnReturn=true
#测试机IP
#redis.ip=192.168.0.250
redis.ip=localhost
#Port
redis.port=6379
直接上代码
- 回调接口
public interface RedisCallback<T> {
public T call(Jedis jedis,Object params);
}
- 客户端
@Component
public class RedisClient {
private static Logger logger = LoggerFactory.getLogger("RedisManager");
private static JedisPool pool = null;
private static String IP_ADDRESS = null;
@PostConstruct
public void initRedisCOnfig() {
try {
logger.info("------------- redis pool init start------------- ");
Properties props = new Properties();
props.load(RedisClient.class.getClassLoader().getResourceAsStream("redis.properties"));
IP_ADDRESS = props.getProperty("redis.ip");
// 创建jedis池配置实例
JedisPoolConfig config = new JedisPoolConfig();
// 设置池配置项值
config.setTestWhileIdle(false);
config.setMaxTotal(Integer.valueOf(props.getProperty("redis.pool.maxTotal")));
config.setMaxIdle(Integer.valueOf(props.getProperty("redis.pool.maxIdle")));
config.setMaxWaitMillis(Long.valueOf(props.getProperty("redis.pool.maxWaitMillis")));
config.setTestOnBorrow(Boolean.valueOf(props.getProperty("redis.pool.testOnBorrow")));
config.setTestOnReturn(Boolean.valueOf(props.getProperty("redis.pool.testOnReturn")));
pool = new JedisPool(config, IP_ADDRESS, Integer.valueOf(props.getProperty("redis.port")));
boolean connected = isConnected();
if(!connected){
logger.error("redis 初始化出错 缓存服务器连接不上! ");
throw new Exception("IP:"+IP_ADDRESS+", redis服务器不可以连接~~~,请检查配置 与redis 服务器");
}
logger.info("------------- redis pool init end------------- ");
} catch (Exception e) {
logger.error(e.getMessage(), e);
throw new Error("IP:" + IP_ADDRESS + ",设置redis服务器出错", e);
}
}
public boolean isConnected() {
return getRedis().isConnected();
}
public void destory() {
pool.destroy();
}
public Jedis getRedis() {
Jedis jedis = pool.getResource();
jedis.select(0);
return jedis;
}
public Jedis getRedis(int index) {
Jedis jedis = pool.getResource();
jedis.select(index);
return jedis;
}
public void returnRedis(Jedis jedis) {
pool.returnResource(jedis);
}
public void returnBrokeRedis(Jedis jedis) {
pool.returnBrokenResource(jedis);
}
}
- key value 的pojo对象
public class RedisKVPO {