当我们使用客户端对 Redis 进行一次操作时,如下图所示,客户端将请求传送给服务器,服务器处理完毕后,再将响应回复给客户端。这要花费一个网络数据包来回的时间。
如果连续执行多条指令,那就会花费多个网络数据包来回的时间。如下图所示。
回到客户端代码层面,客户端是经历了写-读-写-读四个操作才完整地执行了两条指令。
现在如果我们调整读写顺序,改成写—写-读-读,这两个指令同样可以正常完成。
两个连续的写操作和两个连续的读操作总共只会花费一次网络来回,就好比连续的 write 操作合并了,连续的 read 操作也合并了一样。
redis 管道技术很简单,就是本身我们有10个指令需要发给服务端,这样我们就需要10次网络请求,是极大消耗资源的,Redis推出了管道后,我们只要将这10条指令打包在一次,一次性发给redis,这样就产生了一次网络请求,大大节省服务器资源