概述
redis是一種基于客戶端-服務端模型以及請求/響應協議的TCP服務。這意味著通常情況下一個請求會遵循以下步驟:
- 客戶端向服務端發送一個查詢請求,并監聽Socket返回,通常是以阻塞模式,等待服務端響應。
- 服務端處理命令,并將結果返回給客戶端。
Redis 管道技術
Redis 管道技術可以在服務端未響應時,客戶端可以繼續向服務端發送請求,并最終一次性讀取所有服務端的響應。
查看 redis 管道,只需要啟動 redis 實例并輸入以下命令:
$(echo -en "PING SET w3ckey redis GET w3ckey INCR visitor INCR visitor INCR visitor "; sleep 10) | nc localhost 6379
以上實例中我們通過使用 PING 命令查看redis服務是否可用, 之后我們們設置了 w3ckey 的值為 redis,然后我們獲取 w3ckey 的值并使得 visitor 自增 3 次。
在返回的結果中我們可以看到這些命令一次性向 redis 服務提交,并最終一次性讀取所有服務端的響應。
管道技術的優勢
管道技術最顯著的優勢是提高了 redis 服務的性能。
在下面的測試中,使用Redis的Ruby客戶端,支持管道技術特性,測試管道技術對速度的提升效果。
從執行上面這個腳本的數據表明,開啟了管道操作后,往返時延已經被改善得相當低了。
開啟管道后,速度效率提升了5倍。
Redis的管道(Pipelining)操作是一種異步的訪問模式,一次發送多個指令,不同步等待其返回結果。這樣可以取得非常好的執行效率。有數據表明,某個后臺應用,逐個處理大約100萬條記錄需要幾十分鐘,經過pileline壓縮請求數量后,最后時間縮小到20秒左右。所以正確使用pipeline對性能的提升十分明顯。