W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
Redis是一種基于客戶端-服務(wù)端模型以及請(qǐng)求/響應(yīng)協(xié)議的TCP服務(wù)。這意味著通常情況下一個(gè)請(qǐng)求會(huì)遵循以下步驟:
Redis 管道技術(shù)可以在服務(wù)端未響應(yīng)時(shí),客戶端可以繼續(xù)向服務(wù)端發(fā)送請(qǐng)求,并最終一次性讀取所有服務(wù)端的響應(yīng)。
查看 redis 管道,只需要啟動(dòng) redis 實(shí)例并輸入以下命令:
$(echo -en "PING\r\n SET w3ckey redis\r\nGET w3ckey\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379 +PONG +OK redis :1 :2 :3
以上實(shí)例中我們通過使用 PING 命令查看redis服務(wù)是否可用, 之后我們們?cè)O(shè)置了 w3ckey 的值為 redis,然后我們獲取 w3ckey 的值并使得 visitor 自增 3 次。
在返回的結(jié)果中我們可以看到這些命令一次性向 redis 服務(wù)提交,并最終一次性讀取所有服務(wù)端的響應(yīng)
管道技術(shù)最顯著的優(yōu)勢(shì)是提高了 redis 服務(wù)的性能。
在下面的測(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ù)表明,開啟了管道操作后,往返時(shí)延已經(jīng)被改善得相當(dāng)?shù)土恕?/p>
without pipelining 1.185238 seconds with pipelining 0.250783 seconds
如你所見,開啟管道后,我們的速度效率提升了5倍。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: