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

什么是流水线技术?

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

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

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

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

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

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值