一、請求應答協議和RTT:
Redis是一種典型的基于C/S模型的TCP服務器。在客戶端與服務器的通訊過程中,通常都是客戶端率先發起請求,服務器在接收到請求后執行相應的任務,最后再將獲取的數據或處理結果以應答的方式發送給客戶端。在此過程中,客戶端都會以阻塞的方式等待服務器返回的結果。見如下命令序列:
Redis在很早的版本中就已經提供了對命令管線的支持。在給出具體解釋之前,我們先將上面的同步應答方式的例子改造為基于命令管線的異步應答方式,這樣可以讓大家有一個更好的感性認識。
以下是來自Redis官網的測試用例和測試結果。需要說明的是,該測試是基于loopback(127.0.0.1)的,因此RTT所占用的時間相對較少,如果是基于實際網絡接口,那么管線機制所帶來的性能提升就更為顯著了。
新聞熱點
疑難解答