Redis核心技术---流水线(pipelined)

什么是流水线技术?

有时候我们需要批量执行一系列redis命令,这个时候如果一条一条的发送给redis,由于网络通信中的延迟,在redis接收到一条命令并且很快执行完后,就会出现等待下一条命令到达的空闲期,这会极大的影响redis的性能。

于是就有了pipelined技术,它可以将一系列命令存到队列中并一次性发送给redis去批量执行,这样就解决了由于网络通信延迟导致redis不断等待新命令到达的问题。

说到队列,有了解redis事务管理的小伙伴就会想起redis也会把事务中的命令存到队列中去批量执行,既然事务也可以实现批量执行,那为什么还要pipelined技术呢?你要知道事务管理是有系统开销的,有时候单纯为了去批量执行一些命令去开启事务是有点不划算的,所以说pipelined技术还是十分有必要的。

下面来对比使用pipelined前和使用后redis存入数据性能差别:

这个例子实现的是统计在1秒内能向redis中存入多少条数据 (示例需导入jedis包)

Redis核心技术---流水线(pipelined)_第1张图片 Redis核心技术---流水线(pipelined)_第2张图片

上面两张图在控制台分别打印出了1秒内redis执行命令的条数,可以看出对比已经非常明显了,在不使用pipelined的时候仅为6381条,而使用pipelined时为238551条。

你可能感兴趣的:(Redis,Redis数据库)