时间:2021-05-02
为啥Redis使用pipelining会更快?
这是一个很考究细节的问题,大部分人都会说:因为减少了网络开销,那么,看如下例子:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 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))为什么执行结果相差如此之大呢?
? 1 2 $ 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使用pipelining会更快的文章就介绍到这了,更多相关Redis使用pipelining快内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://jiajunhuang.com/articles/2020_11_02-why_pipelining_fast.md.html
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.network.http.pipelining 在Filter中输入network.http.pipelining,双击赋值为true,默认为false。
redis中的数据结构和编码:背景:1>redis在内部使用redisObject结构体来定义存储的值对象。2>每种类型都有至少两种内部编码,Redis会根据当
查看Redis内存使用info命令用于监控Redis运行情况,其中infomemory可以查看Redis内存使用统计信息:?1redis-cliinfomemo
方法一:使用pipeline 使用pipelining发送命令时,redisserver必须部分请求放到队列中(使用内存)执行完毕后一次性发送结果,在pipe
上一篇:C#Redis学习系列一:Redis的认识、下载、安装、使用一.redis设置密码使用下载好的redis-cli.exe指令:1.设置密码:config