Redis 管道技术

Redis管道技术


管道技术(Pipeline)是客户端提供的一种批处理技术,用于一次处理多个Redis,从而提高整个交互的性能。

通常情况下Redis是单线程执行的,客户端先向服务器发送请求,服务端接收并处理请求、然后把结果返回给客户端,这种处理模式在非频繁请求时不会出现任何问题。

但如果出现集中大批量请求时,因为每个请求都要经历先请求再响应的过程,这就会造成网络资源浪费。此时就需要管道技术来把所有的命令整合起来,一次性发送给服务端,服务端处理完毕之后一次性响应给客户端,这样就大大地提高了Redis的响应速度。

下面是普通命令模式和管道命令模式的区别

  • 普通命令模式

Redis普通命令模式

  • 管道模式

Redis管道模式

示例

查看 redis 管道,只需要启动 redis 实例并输入以下命令:

$(echo -en "PING\r\n SET jiyikey redis\r\nGET jiyikey\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379

+PONG
+OK
redis
:1
:2
:3

以上实例中我们通过使用 PING 命令查看redis服务是否可用, 之后我们设置了 jiyikey 的值为 redis,然后我们获取 jiyikey 的值并使得 visitor 自增 3 次。

在返回的结果中我们可以看到这些命令一次性向 redis 服务提交,并最终一次性读取所有服务端的响应

管道技术解决了什么问题?


管道技术解决了多个命令集中请求时造成网络资源浪费的问题,加快了 Redis 的响应速度,让 Redis 拥有更高的运行速度。但要注意的一点是,管道技术本质上是客户端提供的功能,而非 Redis 服务器端的功能。

在下面的测试中,我们将使用Redis的Ruby客户端,支持管道技术特性,测试管道技术对速度的提升效果。

require 'rubygems' 
require 'redis'
def bench(descr) 
start = Time.now 
yield 
puts "#{descr} #{Time.now-start} seconds" 
end
def without_pipelining 
r = Redis.new 
10000.times { 
    r.ping 
} 
end
def with_pipelining 
r = Redis.new 
r.pipelined { 
    10000.times { 
        r.ping 
    } 
} 
end
bench("without pipelining") { 
    without_pipelining 
} 
bench("with pipelining") { 
    with_pipelining 
}

从处于局域网中的Mac OS X系统上执行上面这个简单脚本的数据表明,开启了管道操作后,往返延时已经被改善得相当低了。

without pipelining 1.185238 seconds 
with pipelining 0.250783 seconds

如你所见,开启管道后,我们的速度效率提升了5倍。

查看笔记

扫码一下
查看教程更方便