概述
redis是一種基于客戶(hù)端-服務(wù)端模型以及請(qǐng)求/響應(yīng)協(xié)議的TCP服務(wù)。這意味著通常情況下一個(gè)請(qǐng)求會(huì)遵循以下步驟:
- 客戶(hù)端向服務(wù)端發(fā)送一個(gè)查詢(xún)請(qǐng)求,并監(jiān)聽(tīng)Socket返回,通常是以阻塞模式,等待服務(wù)端響應(yīng)。
- 服務(wù)端處理命令,并將結(jié)果返回給客戶(hù)端。

Redis 管道技術(shù)
Redis 管道技術(shù)可以在服務(wù)端未響應(yīng)時(shí),客戶(hù)端可以繼續(xù)向服務(wù)端發(fā)送請(qǐng)求,并最終一次性讀取所有服務(wù)端的響應(yīng)。
查看 redis 管道,只需要啟動(dòng) redis 實(shí)例并輸入以下命令:
$(echo -en "PING SET w3ckey redis GET w3ckey INCR visitor INCR visitor INCR visitor "; sleep 10) | nc localhost 6379

以上實(shí)例中我們通過(guò)使用 PING 命令查看redis服務(wù)是否可用, 之后我們們?cè)O(shè)置了 w3ckey 的值為 redis,然后我們獲取 w3ckey 的值并使得 visitor 自增 3 次。
在返回的結(jié)果中我們可以看到這些命令一次性向 redis 服務(wù)提交,并最終一次性讀取所有服務(wù)端的響應(yīng)。
管道技術(shù)的優(yōu)勢(shì)
管道技術(shù)最顯著的優(yōu)勢(shì)是提高了 redis 服務(wù)的性能。
在下面的測(cè)試中,使用Redis的Ruby客戶(hù)端,支持管道技術(shù)特性,測(cè)試管道技術(shù)對(duì)速度的提升效果。

從執(zhí)行上面這個(gè)腳本的數(shù)據(jù)表明,開(kāi)啟了管道操作后,往返時(shí)延已經(jīng)被改善得相當(dāng)?shù)土恕?/p>
開(kāi)啟管道后,速度效率提升了5倍。
Redis的管道(Pipelining)操作是一種異步的訪(fǎng)問(wèn)模式,一次發(fā)送多個(gè)指令,不同步等待其返回結(jié)果。這樣可以取得非常好的執(zhí)行效率。有數(shù)據(jù)表明,某個(gè)后臺(tái)應(yīng)用,逐個(gè)處理大約100萬(wàn)條記錄需要幾十分鐘,經(jīng)過(guò)pileline壓縮請(qǐng)求數(shù)量后,最后時(shí)間縮小到20秒左右。所以正確使用pipeline對(duì)性能的提升十分明顯。