欢迎来到代码驿站!

Redis

当前位置:首页 > 数据库 > Redis

为啥Redis使用pipelining会更快

时间:2021-05-19 09:40:48|栏目:Redis|点击:

为啥Redis使用pipelining会更快?

这是一个很考究细节的问题,大部分人都会说:因为减少了网络开销,那么,看如下例子:

import time

import redis

client = redis.Redis(decode_responses=True)
count = 10000


def no_pipelining():
  for i in range(count):
    client.set("test:nopp:{}".format(i), i, ex=100)


def with_pipelining():
  pp = client.pipeline()

  for i in range(count):
    pp.set("test:withpp:{}".format(i), i, ex=100)

  pp.execute()


if __name__ == "__main__":
  start = time.time()
  no_pipelining()
  mid = time.time()
  with_pipelining()
  end = time.time()

  print("no_pipelining: {} seconds; with_pipelining: {} seconds".format(mid - start, end - mid))

为什么执行结果相差如此之大呢?

$ python test.py
no_pipelining: 2.3809118270874023 seconds; with_pipelining: 0.4370129108428955 seconds

因为这是连接本地的redis,所以网络开销非常小,当然,这里仍然有一部分是网络开销影响,可是除此之外是否还有其它影响因素呢? 答案是有,比如OS进程调度,当不使用管道时,Redis处理每个命令之间是有时间空隙的,因此OS很有可能会将Redis进程转换为sleep状态, 然后运行其它程序,而使用pipelining时,可以提高CPU利用率,Redis空闲的时间没有那么多,因此,这也是pipelining速度会更快的 重要原因之一。

ref:

https://redis.io/topics/pipelining

上一篇:在Redis数据库中实现分布式速率限制的方法

栏    目:Redis

下一篇:Redis主从复制问题和扩容问题的解决思路

本文标题:为啥Redis使用pipelining会更快

本文地址:http://www.codeinn.net/misctech/124450.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有