java对Redis 封装

这篇博客介绍了作者在公司项目中对Redis进行的简单封装,包括参考他人代码和GitHub资源,主要涉及了配置文件、回调接口、客户端操作、Key-Value POJO对象及模板代码,旨在方便释放连接并鼓励读者交流优化建议。
摘要由CSDN通过智能技术生成

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

直接上代码

  1. 回调接口
public interface RedisCallback<T> {
    public T call(Jedis jedis,Object params);
}
  1. 客户端
@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);
    }

}
  1. key value 的pojo对象
public class RedisKVPO {
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值