redis学习(十七) 使用shardedJedis

使用shardedJedis

ShardedJedis是通过一致性哈希来实现分布式缓存的,通过一定的策略把不同的key分配到不同的redis server上,达到横向扩展的目的,废话不多说直接上一个测试代码吧,代码里会有注释。

代码github地址: github地址

public class ShareJedisTest {
    public static void main(String[] args) {
        //设置连接池的相关配置
        JedisPoolConfig poolConfig = new JedisPoolConfig();
        poolConfig.setMaxTotal(2);
        poolConfig.setMaxIdle(1);
        poolConfig.setMaxWaitMillis(2000);
        poolConfig.setTestOnBorrow(false);
        poolConfig.setTestOnReturn(false);

        //设置Redis信息
        String host = "192.168.72.128";
        JedisShardInfo shardInfo1 = new JedisShardInfo(host, 6379, 5000);
        JedisShardInfo shardInfo2 = new JedisShardInfo(host, 6381, 5000);


        //初始化ShardedJedisPool
        List<JedisShardInfo> infoList = Arrays.asList(shardInfo1, shardInfo2);
        ShardedJedisPool jedisPool = new ShardedJedisPool(poolConfig, infoList);

        //进行查询等其他操作
        ShardedJedis jedis = null;
        try {
            jedis = jedisPool.getResource();
            jedis.set("test", "test");
            jedis.set("test1", "test1");
            jedis.set("test2", "test2");
            jedis.set("test3", "test3");
            jedis.set("test4", "test4");

            //查看具体key在哪个客户端
            Client client0 = jedis.getShard("test").getClient();
            Client client1 = jedis.getShard("test1").getClient();
            Client client2 = jedis.getShard("test2").getClient();
            Client client3 = jedis.getShard("test3").getClient();
            Client client4 = jedis.getShard("test4").getClient();
            System.out.println(client0.getHost() + ":" + client0.getPort());
            System.out.println(client1.getHost() + ":" + client1.getPort());
            System.out.println(client2.getHost() + ":" + client2.getPort());
            System.out.println(client3.getHost() + ":" + client3.getPort());
            System.out.println(client4.getHost() + ":" + client4.getPort());
        } finally {
            //使用后一定关闭,还给连接池
            if(jedis!=null) {
                jedis.close();
            }
        }
    }
}

上一篇 使用jedis执行lua脚本(实现一个对IP的限流)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值