redis的管道機(jī)制是如何實(shí)現(xiàn)的?
目前來看,redis的管道機(jī)制的實(shí)現(xiàn)是通過使用批量操作進(jìn)行發(fā)送命令和返回,其結(jié)果可以稱為 Round Trip Time (RTT,往返時(shí)間)。
在Redis中提供了批量操作命令,例如mget、mset等,有效地節(jié)約了RTT。但是大部分命令是不支持批量操作的。
為此,Redis提供了一個(gè)稱為管道(Pipeline) 的機(jī)制將一組Redis命令進(jìn)行組裝,通過一次 RTT 傳輸給 Redis,再將這些 Redis 命令的執(zhí)行結(jié)果按順序傳遞給客戶端。即使用pipeline執(zhí)行了n次命令,整個(gè)過程就只需要一次 RTT。
它的好處來源于管道機(jī)制,Pipeline管道機(jī)制不單單是為了減少RTT的一種方式,它實(shí)際上大大提高了Redis的QPS。原因是,在沒有使用管道機(jī)制的情況下,從訪問數(shù)據(jù)結(jié)構(gòu)和產(chǎn)生回復(fù)的角度來看,為每個(gè)命令提供服務(wù)是非常便宜的。
但是從底層套接字的角度來看,這是非常昂貴的,這涉及read()和write()系統(tǒng)調(diào)用,從用戶態(tài)切換到內(nèi)核態(tài),這種上下文切換開銷是巨大。
而使用Pipeline的情況下,通常使用單個(gè)read()系統(tǒng)調(diào)用讀取許多命令,然后使用單個(gè)write()系統(tǒng)調(diào)用傳遞多個(gè)回復(fù),這樣就提高了QPS。
簡(jiǎn)而言之,就是提升了運(yùn)行的速度以及效果。其中,QPS(Query Per Second)就是數(shù)據(jù)運(yùn)行的一個(gè)重要指標(biāo),QPS 其實(shí)是衡量吞吐量(Throughput)的一個(gè)常用指標(biāo),就是說服務(wù)器在一秒的時(shí)間內(nèi)處理了多少個(gè)請(qǐng)求。