Redis 管道操作

Redis 管道操作

因为在操作Redis的时候,执行一个命令需要先发送请求到Redis服务器,这个过程需要经历网络的延迟,Redis还需要给客户端一个相应

如果我需要一次性执行很多个命令,上述的方式效率很低,可以通过Redis的管道,先将命令放到客户短的一个Pipeline中,之后一次性的将全部命令都发送到Redis服务,Redis服务一次性的将全部的返回结果相应给客户端。

对比:前:未使用管道(376211毫秒),后:管道操作(339毫秒)

@Test
void notPipeline() {
    // 未使用Redis 管道
    // 1.创建连接池
    JedisPool jedisPool = new JedisPool(new GenericObjectPoolConfig(), "101.21.114.44", 6379, 10000, "root");
    long l = System.currentTimeMillis(); // 当前时间
    // 2.获取jedis对象
    Jedis jedis = jedisPool.getResource();
    // 3.执行incr 10000次
    for (int i = 0; i < 10000; i++) {
        jedis.incr("pp");
    }
    // 4.释放资源
    jedis.close();
    // 使用时间(毫秒):376211
    System.out.println(System.currentTimeMillis() - l);
}
@Test
void pipeline(){
    // 1.创建连接池
    JedisPool jedisPool = new JedisPool(new GenericObjectPoolConfig(), "101.21.114.44", 6379, 10000, "root");
    long l = System.currentTimeMillis(); // 当前时间
    // 2.获取jedis对象
    Jedis jedis = jedisPool.getResource();
    // 3.创建管道
    Pipeline pipelined = jedis.pipelined();
    // 4.执行incr 10000次
    for (int i = 0; i < 10000; i++) {
      	// 放入管道
        pipelined.incr("qq");
    }
  	// 传输管道,进行执行
    pipelined.syncAndReturnAll();
    // 5.释放资源
    jedis.close();
    // 使用时间(毫秒):339
    System.out.println(System.currentTimeMillis() - l);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值