Redis管道

目录

1、什么是管道?

2、案例演示

3、注意事项

4、面试题


1、什么是管道?

管道(pipeline)可以一次性发送多条命令给服务端,服务端依次处理完,通过一条响应一次性将结果返回,减少 IO 的次数,缩短往返回时间。

类似于 mset、mget 命令...

2、案例演示

# 创建一个文本文件,保存即将执行的redis命令
[root@localhost ~]# cat pipe.txt 
set kk vv
set kkk vvv
rpush list 1 2 3 4
hset user age 11
hset user name 'lisi'
zadd set 1 2 3 4

# 使用管道符,将上述的redis命令交给客户端执行
[root@localhost ~]# cat pipe.txt | redis-cli  --pipe
All data transferred. Waiting for the last reply...
Last reply received from server.
# 错误:0  回复:6 表示命令执行成功
errors: 0, replies: 6
[root@localhost ~]# 

执行结果

# 执行前
127.0.0.1:6379> keys *

# 执行后
127.0.0.1:6379> keys *
set
kkk
kk
list
user
127.0.0.1:6379> 

3、注意事项

pipeline 与原生批量命令的对比

  1. 原生批量命令(mset、mget..)是原子性,而 pipeline 是非原子性操作
  2. 原生批量命令一次只能操作一种类型的数据,而 pipeline 可以操作多种
  3. 原生批量命令是由服务端完成,pipeline 是客户端+服务端共同完成 

使用pipeline 注意事项:

  1.   pipeline 缓冲的指令不保证原子性,如果执行指令发生异常,将会继续执行后序的指令
  2. 使用 pipeline 组装的命令个数不能太多,不然数据量过大客户端阻塞的时间可能过久,同时服务器此时也被迫回复一个队列答复,占用很多内存。

4、面试题

为什么要使用  pipleline,他有什么好处?

使用 pipeline (管道)的好处在于可以 将多次 I/O 往返的时间缩短为一次 ,但是要求管道中执行的指令间没有因果关系。
pipeline 的原因在于可以实现请求 / 响应服务器的功能,当客户端尚未读取旧响应时,它也可以
处理新的请求。如果客户端存在多个命令发送到服务器时,那么客户端无需等待服务端的每次响应
才能执行下个命令,只需最后一步从服务端读取回复即可。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鲨瓜2号

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

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

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

打赏作者

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

抵扣说明:

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

余额充值