redis学习之JedisPool+JedisCluster

redis学习之JedisPool+JedisCluster

JedisPool

public class RedisPool {

    private static JedisPool pool = null;
    static{
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(500);
        // 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例。
        config.setMaxIdle(5);
        // 表示当borrow(引入)一个jedis实例时,最大的等待时间,如果超过等待时间,则直接抛出JedisConnectionException;
        config.setMaxWaitMillis(100*1000);
        // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
        config.setTestOnBorrow(true);
        pool = new JedisPool(config,"192.168.235.100",6379,10000);
    }

    public static Jedis getJedis(){
        return pool.getResource();
    }

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

	@Test
    public void testStock() throws InterruptedException {
        Jedis jedis = RedisPool.getJedis();
        try {
            int stock = Integer.parseInt(jedis.get("stock"));
            System.out.println(stock);
        } finally {
            RedisPool.release(jedis);
        }
    }

JedisCluster

public class JedisClusterPool {
    private static JedisCluster jedisCluster;

    public static JedisCluster  getJedisCluster(){
        if(jedisCluster==null){
            synchronized (JedisClusterPool.class){
                if(jedisCluster==null){
                    Set<HostAndPort> hostAndPortsSet = new HashSet<HostAndPort>();
                    // 添加节点
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6380));
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6381));
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6382));
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6390));
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6391));
                    hostAndPortsSet.add(new HostAndPort("192.168.235.100", 6392));
                    JedisPoolConfig config = new JedisPoolConfig();
                    config.setMaxTotal(500);
                    // 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例。
                    config.setMaxIdle(5);
                    // 表示当borrow(引入)一个jedis实例时,最大的等待时间,如果超过等待时间,则直接抛出JedisConnectionException;
                    config.setMaxWaitMillis(100*1000);
                    // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
                    config.setTestOnBorrow(true);
                    jedisCluster = new JedisCluster(hostAndPortsSet, config);
                }
            }
        }
        return jedisCluster;
    }

}

@Test
    public void testCluster() throws InterruptedException {
        System.out.println(JedisClusterPool.getJedisCluster().get("stock"));
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值