Redis 管道技術(shù)

Redis是一種基于客戶端-服務(wù)端模型以及請(qǐng)求/響應(yīng)協(xié)議的TCP服務(wù)。這意味著通常情況下一個(gè)請(qǐng)求會(huì)遵循以下步驟:

  • 客戶端向服務(wù)端發(fā)送一個(gè)查詢請(qǐng)求,并監(jiān)聽(tīng)Socket返回,通常是以阻塞模式,等待服務(wù)端響應(yīng)。

  • 服務(wù)端處理命令,并將結(jié)果返回給客戶端。

Redis 管道技術(shù)

Redis 管道技術(shù)可以在服務(wù)端未響應(yīng)時(shí),客戶端可以繼續(xù)向服務(wù)端發(fā)送請(qǐng)求,并最終一次性讀取所有服務(wù)端的響應(yīng)。

在線示例

查看 redis 管道,只需要啟動(dòng) redis 示例并輸入以下命令:

$(echo -en "PING\r\n SET nhoookey redis\r\nGET nhoookey\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379
+PONG
+OK
redis
:1
:2
:3

以上示例中我們通過(guò)使用 PING 命令查看redis服務(wù)是否可用, 之后我們?cè)O(shè)置了 nhoookey 的值為 redis,然后我們獲取 nhoookey 的值并使得 visitor 自增 3 次。

在返回的結(jié)果中我們可以看到這些命令一次性向 redis 服務(wù)提交,并最終一次性讀取所有服務(wù)端的響應(yīng)

管道技術(shù)的優(yōu)勢(shì)

管道技術(shù)最顯著的優(yōu)勢(shì)是提高了 redis 服務(wù)的性能。

一些測(cè)試數(shù)據(jù)

在下面的測(cè)試中,我們將使用Redis的Ruby客戶端,支持管道技術(shù)特性,測(cè)試管道技術(shù)對(duì)速度的提升效果。

require 'rubygems' 
require 'redis'
def bench(descr) 
start = Time.now 
yield 
puts "#{descr} #{Time.now-start} seconds" 
end
def without_pipelining 
r = Redis.new 
10000.times { 
    r.ping 
} 
end
def with_pipelining 
r = Redis.new 
r.pipelined { 
    10000.times { 
        r.ping 
    } 
} 
end
bench("without pipelining") { 
    without_pipelining 
} 
bench("with pipelining") { 
    with_pipelining 
}

從處于局域網(wǎng)中的Mac OS X系統(tǒng)上執(zhí)行上面這個(gè)簡(jiǎn)單腳本的數(shù)據(jù)表明,開(kāi)啟了管道操作后,往返延時(shí)已經(jīng)被改善得相當(dāng)?shù)土恕?/p>

without pipelining 1.185238 seconds 
with pipelining 0.250783 seconds

如你所見(jiàn),開(kāi)啟管道后,我們的速度效率提升了5倍。

丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清