REDIS04_管道的概念、案列演示、管道总结

文章目录

  • [①. 管道(pipeline)概念](#①. 管道(pipeline)概念)
  • [②. 管道案列演示](#②. 管道案列演示)
  • [③. 管道命令总结](#③. 管道命令总结)

①. 管道(pipeline)概念

  • ①. 管道(pipeline)可以一次性发送多条命令给服务端,服务端依次处理完完毕后,通过一条响应一次性将结果返回,通过减少客户端与redis的通信次数来实现降低往返延时时间。 pipeline实现的原理是队列,先进先出特性就保证数据的顺序性
  1. Pipeline是为了解决RTT往返回时,仅仅是将命令打包一次性发送,对整个Redis的执行不造成其它任何影响
  2. Round Trip Time(简称RTT,数据包往返于两端的时间)

②. 管道案列演示

③. 管道命令总结

  • ①. Pipeline与原生批量命令对比
  1. 原生批量命令是原子性(例如:mset, mget),pipeline是非原子性
  2. 原生批量命令一次只能执行一种命令,pipeline支持批量执行不同命令
  3. 原生批命令是服务端实现,而pipeline需要服务端与客户端共同完成
  • ②. 使用Pipeline注意事项
  1. pipeline缓冲的指令只是会依次执行,不保证原子性 ,如果执行中指令发生异常,将会继续执行后续的指令
  2. 使用pipeline组装的命令个数不能太多,不然数据量过大客户端阻塞的时间可能过久,同时服务端此时也被迫回复一个队列答复,占用很多内存
相关推荐
爬山算法3 小时前
Redis(166)如何使用Redis实现实时统计?
java·redis·bootstrap
羑悻的小杀马特3 小时前
Stream消息队列+地理空间计算+HyperLogLog去重,SCAN安全遍历+RESP协议全解析,一文把它啃透!
数据库·redis·安全·缓存·空间计算·resp
JIAWAP3 小时前
Redis数据安全性分析之RDB详解
数据库·redis·分布式·缓存
2501_916766543 小时前
【Mybatis】延迟加载与多级缓存
缓存·mybatis
黛琳ghz4 小时前
极速云原生:openEuler之Redis与Nginx部署性能实战
redis·nginx·云原生·操作系统·压力测试·openeuler·服务器部署
此生只爱蛋4 小时前
【Redis】浅谈数据结构和内部编码和单线程架构
数据结构·数据库·redis
雨落秋垣4 小时前
SpringCache 缓存:注意事项、问题解决与优化策略
java·spring·缓存
奶油松果15 小时前
Springboot自动装配 - redis和redission
java·spring boot·redis
siriuuus16 小时前
Redis 安装、多实例部署、主从复制及 Cluster 实践
数据库·redis·centos