Redis 管道

目录

Redis 管道

Abstract

管道和原生批命令的比较

管道和脚本的区别

使用管道需要注意的事项


Redis 管道

Abstract

Redis 客户端执行一条命令分 4 个过程:

发送命令-〉命令排队-〉命令执行-〉返回结果

这个过程称为 Round trip time(简称 RTT, 往返时间),Redis 的原生批命令(mget 和 mset)有效节约了 RTT,但大部分命令不支持批量操作,

需要消耗 N 次 RTT ,这个时候需要 pipeline 来解决这个问题

Pipeline 是为了解决 RTT 往返回时,仅仅是将命令打包一次性发送,对整个 Redis 的执行不选成其它任何影响

管道和原生批命令的比较

实现方式:

管道命令需要服务端与客户端共同完成,而原生的批命令只由服务端去实现

原子性:

管道命令不具有原子性,出现问题不回滚。

管道和脚本的区别

1. Redis 的 Script 会当成一个命令,具有原子性,在执行 Script 的时候不会被其他的命令插入,因此更适合于处理事务;

2. 管道虽然也会将多个命令一次性传输到服务端,但在服务端执行的时候仍然是多个命令,如在执行 CMD1 的时候,外部另一个客户端提交了 CMD9,会先执行完 CMD9 再执行管道中的 CMD2,因此事实上管道是不具有原子性的

使用管道需要注意的事项

1. 使用 pipeline 组装的命令个数不能太多,否则数据量过大,增加客户端的等待时间,还可能造成网络阻塞,可以适当地将大量命令的拆分成多个小的 pipeline 命令完成(看具体情况)

2. pipeline 特别命令数据初始化加载程序,可大大提供效率

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ym影子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值