為啥Redis使用pipelining會更快
為啥Redis使用pipelining會更快?
這是一個很考究細節(jié)的問題,大部分人都會說:因為減少了網(wǎng)絡(luò)開銷,那么,看如下例子:
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))
為什么執(zhí)行結(jié)果相差如此之大呢?
$ python test.py no_pipelining: 2.3809118270874023 seconds; with_pipelining: 0.4370129108428955 seconds
因為這是連接本地的redis,所以網(wǎng)絡(luò)開銷非常小,當(dāng)然,這里仍然有一部分是網(wǎng)絡(luò)開銷影響,可是除此之外是否還有其它影響因素呢? 答案是有,比如OS進程調(diào)度,當(dāng)不使用管道時,Redis處理每個命令之間是有時間空隙的,因此OS很有可能會將Redis進程轉(zhuǎn)換為sleep狀態(tài), 然后運行其它程序,而使用pipelining時,可以提高CPU利用率,Redis空閑的時間沒有那么多,因此,這也是pipelining速度會更快的 重要原因之一。
ref:
https://redis.io/topics/pipelining
到此這篇關(guān)于為啥Redis使用pipelining會更快的文章就介紹到這了,更多相關(guān)Redis使用pipelining快內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis遍歷海量數(shù)據(jù)集的幾種實現(xiàn)方法
Redis作為一個高性能的鍵值存儲數(shù)據(jù)庫,廣泛應(yīng)用于各種場景,包括緩存、消息隊列、排行榜,本文主要介紹了Redis遍歷海量數(shù)據(jù)集的幾種實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-02-02
Windows系統(tǒng)安裝redis數(shù)據(jù)庫
這篇文章介紹了Windows系統(tǒng)安裝redis數(shù)據(jù)庫的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03

