redis 管道技術(shù)

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

客戶端向服務(wù)端發(fā)送一個查詢請求进副,并監(jiān)聽Socket返回,通常是以阻塞模式曾沈,等待服務(wù)端響應(yīng)鸥昏。

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

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

實例

查看 redis 管道痹换,只需要啟動 redis 實例并輸入以下命令:

$(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

以上實例中我們通過使用?PING?命令查看redis服務(wù)是否可用, 之后我們們設(shè)置了 w3ckey 的值為 redis匙姜,然后我們獲取 w3ckey 的值并使得 visitor 自增 3 次冯痢。

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

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

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

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

在下面的測試中,我們將使用Redis的Ruby客戶端梧乘,支持管道技術(shù)特性庐杨,測試管道技術(shù)對速度的提升效果夹供。

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í)行上面這個簡單腳本的數(shù)據(jù)表明哮洽,開啟了管道操作后,往返時延已經(jīng)被改善得相當?shù)土恕?/p>

without pipelining 1.185238 seconds

with pipelining 0.250783 seconds

如你所見氛什,開啟管道后匪凉,我們的速度效率提升了5倍。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贸铜,一起剝皮案震驚了整個濱河市聂受,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌棍鳖,老刑警劉巖碗旅,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異骂蓖,居然都是意外死亡川尖,警方通過查閱死者的電腦和手機茫孔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門缰贝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來畔濒,“玉大人,你說我怎么就攤上這事赞弥∪ば郑” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵拼窥,是天一觀的道長蹋凝。 經(jīng)常有香客問我,道長改含,這世上最難降的妖魔是什么伐割? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任隔心,我火速辦了婚禮,結(jié)果婚禮上硬霍,老公的妹妹穿的比我還像新娘。我一直安慰自己粱玲,他們只是感情好拜轨,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布橄碾。 她就那樣靜靜地躺著颠锉,像睡著了一般史汗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上停撞,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天戈毒,我揣著相機與錄音,去河邊找鬼副硅。 笑死恐疲,一個胖子當著我的面吹牛套么,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播胚泌,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼玷室,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了敌蜂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤津肛,失蹤者是張志新(化名)和其女友劉穎章喉,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體身坐,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡秸脱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了部蛇。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片摊唇。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖涯鲁,靈堂內(nèi)的尸體忽然破棺而出巷查,到底是詐尸還是另有隱情有序,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布笔呀,位于F島的核電站,受9級特大地震影響髓需,放射性物質(zhì)發(fā)生泄漏许师。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一僚匆、第九天 我趴在偏房一處隱蔽的房頂上張望微渠。 院中可真熱鬧,春花似錦咧擂、人聲如沸逞盆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽云芦。三九已至,卻和暖如春贸桶,著一層夾襖步出監(jiān)牢的瞬間舅逸,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工皇筛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留琉历,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓水醋,卻偏偏與公主長得像旗笔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子拄踪,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Redis 管道技術(shù) Redis是一種基于客戶端-服務(wù)端模型以及請求/響應(yīng)協(xié)議的TCP服務(wù)蝇恶。這意味著通常情況下一個...
    stakeing閱讀 656評論 0 0
  • Redis是一種基于客戶端-服務(wù)端模型以及請求/響應(yīng)協(xié)議的TCP服務(wù)。這意味著通常情況下一個請求會遵循以下步驟: ...
    Uzero閱讀 3,299評論 0 2
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理宫蛆,服務(wù)發(fā)現(xiàn)艘包,斷路器,智...
    卡卡羅2017閱讀 134,662評論 18 139
  • Redis 配置文件示例 注意:想要讀取配置文件耀盗,Redis的第一個參數(shù)必須是文件的路徑 ./redis-serv...
    起個名忒難閱讀 1,198評論 0 1
  • 從2017的第一天開始就每日寫作1000字想虎,到加入社群前已經(jīng)堅持寫作一百多天,相比這周的公開寫作叛拷,我過去更多是私下...
    張志鑫閱讀 297評論 0 2