Java实现Redis批量读取List

当我们使用Redis队列进行大量数据存取时,RPUSH可以实现一次存入多条数据,而逐条LPOP性能往往不尽如人意。这时就需要批量读取List中的数据再进行处理,减少redis读写次数。幸好redis提供了lrange方法,可以实现list的批量读取。
Java代码如下:

    public static void main(String[] args) {
        Jedis jedis = null;
        String listName = "test";
        String redisHost = "localhost";
        String redisPwd = "123456";
        int redisPort = 6379;
        int i = 0;
        Long begin = Calendar.getInstance().getTimeInMillis();
        try {
            List list=new ArrayList();
            //获取jedis连接
            jedis = JedisUtil.getDataJedis(redisHost, redisPort, redisPwd);
            while (true) {
            //从List批量获取数据,每次取200条
                list = jedis.lrange(listName,0,199);
                int num=list.size();
                if(num == 0){
                    Thread.sleep(1000);
                    continue;
                }
                System.out.println("从list获取到"+num+"条数据");
                //将list做修剪,去掉已经读出的数据
                jedis.ltrim(listName,num,-1);
                i+=num;
                if (i>10000){
                    break;
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            if (jedis!=null){
                jedis.close();
            }
        }
        Long end = Calendar.getInstance().getTimeInMillis();
        System.out.println("读取"+i+"条共耗时:[" + (end-begin)+"]ms");
    }

这是使用RPUSH,LPOP的情况,如果是从左端写入的lpush怎么办呢?别急 Lrange还可以从右侧读取,只要把游标改成负数即可,-1即队列最后一条数据。注意标号要从左到右。另外lrange的标号参数都是左右包含的闭区间

		try {
            List list=new ArrayList();
            jedis = JedisUtil.getDataJedis(redisHost, redisPort, redisPwd);
            while (true) {
            //从List右侧批量获取数据,每次取200条
                list = jedis.lrange(listName,-200,-1);
                int num=list.size();
                if(num == 0){
                    Thread.sleep(1000);
                    continue;
                }
                System.out.println("从list获取到"+num+"条数据");
                jedis.ltrim(listName,0,-201);
                i+=num;
                if (i>10000){
                    break;
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            if (jedis!=null){
                jedis.close();
            }
        }
  • 7
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值