redis相關(guān):IO多路復(fù)用

前言

用過(guò)redis的人拓颓,或者去面試的人被問(wèn)redis的問(wèn)題讲坎,基本都會(huì)了解redis特別快。
redis高校的原因:

  • 1.單線程政己,減少了線程切換的消耗酌壕。
  • 2.基于內(nèi)存操作
  • 3.IO多路復(fù)用

說(shuō)起IO多路復(fù)用,可以先從IO模型開(kāi)始了解歇由。

BIO

BIO是一種同步阻塞的IO模型卵牍,由用戶程序線程發(fā)起請(qǐng)求,完成數(shù)據(jù)的復(fù)制接收沦泌。


BIO 同步阻塞IO模型.png

NIO

NIO是一種同步非阻塞的I/O模型糊昙,也是I/O多路復(fù)用的基礎(chǔ),成為解決高并發(fā)與大量連接谢谦、I/O處理問(wèn)題的有效方式释牺。


NIO 同步非阻塞IO模型.png

IO多路復(fù)用

IO多路復(fù)用模型,就是通過(guò)一種新的系統(tǒng)調(diào)用回挽,一個(gè)進(jìn)程可以監(jiān)視多個(gè)文件描述符没咙,一旦某個(gè)描述符就緒(一般是內(nèi)核緩沖區(qū)可讀/可寫(xiě)),內(nèi)核kernel能夠通知程序進(jìn)行相應(yīng)的IO系統(tǒng)調(diào)用千劈。
目前支持IO多路復(fù)用的系統(tǒng)調(diào)用祭刚,有 select,epoll等等墙牌。select系統(tǒng)調(diào)用袁梗,是目前幾乎在所有的操作系統(tǒng)上都有支持,具有良好跨平臺(tái)特性憔古。epoll是在linux 2.6內(nèi)核中提出的,是select系統(tǒng)調(diào)用的linux增強(qiáng)版本淋袖。


IO多路復(fù)用IO模型.png

異步IO模型 AIO

在內(nèi)核kernel的等待數(shù)據(jù)和復(fù)制數(shù)據(jù)的兩個(gè)階段鸿市,用戶線程都不是block(阻塞)的。用戶線程需要接受kernel的IO操作完成的事件,或者說(shuō)注冊(cè)IO操作完成的回調(diào)函數(shù)焰情,到操作系統(tǒng)的內(nèi)核陌凳。所以說(shuō),異步IO有的時(shí)候内舟,也叫做信號(hào)驅(qū)動(dòng) IO 合敦。


異步IO模型.png

多種IO模型區(qū)別

在以上多種IO模型中,各個(gè)模型有自己的特點(diǎn)验游,也有各自的優(yōu)缺點(diǎn)充岛。

BIO的優(yōu)缺點(diǎn)

優(yōu)點(diǎn):

  • 1.BIO模型程序簡(jiǎn)單,用戶線程基本不會(huì)占用CPU資源耕蝉,無(wú)需線程切換崔梗。
  • 2.在并發(fā)量小的情況下適用,不必用其他復(fù)雜的IO模型來(lái)解決問(wèn)題垒在。

缺點(diǎn):

  • 1.每個(gè)連接配套一條獨(dú)立的線程蒜魄,在高并發(fā)的情況下,對(duì)內(nèi)存场躯、線程切換開(kāi)銷非常巨大谈为。

綜上,在簡(jiǎn)單的低并發(fā)的場(chǎng)景下踢关,為了降低程序的復(fù)雜度伞鲫,可以使用BIO,在高并發(fā)的場(chǎng)景下耘成,不建議使用榔昔。

NIO的優(yōu)缺點(diǎn)

優(yōu)點(diǎn):

  • 線程非阻塞,實(shí)時(shí)性好瘪菌。

缺點(diǎn):

  • 輪詢的行為撒会,毫無(wú)疑問(wèn)的講占用大量的CPU時(shí)間,系統(tǒng)資源利用率也會(huì)下降师妙。

綜上诵肛,可以看出,雖然具有非阻塞的特點(diǎn)默穴,但是在高并發(fā)的場(chǎng)景下怔檩,也存在著巨大的消耗問(wèn)題。單純的使用NIO蓄诽,并不建議使用薛训。

異步IO模型

優(yōu)點(diǎn):

  • 線程非阻塞

缺點(diǎn):

  • 需要用戶程序或者內(nèi)核空間做一系列事情來(lái)完成上述功能。
  • 提出時(shí)間較短仑氛,并沒(méi)有非常完善的解決方案乙埃。

綜上闸英,雖然從模型上看,異步IO模型在各方面綜合比較來(lái)說(shuō)介袜,的確有非常大的優(yōu)勢(shì)甫何,但是還在完善階段,未來(lái)肯定會(huì)有更好的發(fā)揮作用遇伞,但是在現(xiàn)在的場(chǎng)景下辙喂,使用的還是相對(duì)較少。

IO多路復(fù)用

優(yōu)點(diǎn):

  • 1.通過(guò)select/epoll優(yōu)勢(shì)鸠珠,一個(gè)線程可以處理更多的連接巍耗,提高了性能,提高了能力跳芳。

缺點(diǎn):

    1. select/epoll的系統(tǒng)調(diào)用芍锦,其實(shí)也是BIO,也是阻塞的飞盆,而且也是通過(guò)輪詢的方式娄琉。

綜上所述,IO多路復(fù)用其實(shí)也是有阻塞的吓歇,只不過(guò)相對(duì)于一個(gè)線程維護(hù)一個(gè)連接孽水,大大提高了性能,減少了系統(tǒng)的開(kāi)銷城看。
IO多路復(fù)用也是大多數(shù)框架使用的IO模型女气。

redis中IO多路復(fù)用

redis服務(wù)器中有兩類事件:

  • 文件事件:redis主進(jìn)程中進(jìn)行處理,主要處理客戶端的連接請(qǐng)求和響應(yīng)
  • 時(shí)間事件:fork出的子進(jìn)程中進(jìn)行處理测柠,服務(wù)器定期或者周期性執(zhí)行的事件炼鞠,例如,rdb轰胁、aof等

文件事件是對(duì)套接字操作的抽象谒主,每當(dāng)一個(gè)套接字準(zhǔn)備好執(zhí)行連接應(yīng)答、寫(xiě)入赃阀、讀取费尽、關(guān)閉等操作時(shí)鸣个,就會(huì)產(chǎn)生一個(gè)文件事件酌予。
包括可讀事件永票、可寫(xiě)事件。
針對(duì)套接字驮俗、文件事件懂缕、文件描述符等概念后續(xù)計(jì)劃出一篇文章進(jìn)行講解。

redis調(diào)用過(guò)程.png

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末王凑,一起剝皮案震驚了整個(gè)濱河市提佣,隨后出現(xiàn)的幾起案子吮蛹,更是在濱河造成了極大的恐慌,老刑警劉巖拌屏,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異术荤,居然都是意外死亡倚喂,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)瓣戚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)端圈,“玉大人,你說(shuō)我怎么就攤上這事子库〔杖ǎ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵仑嗅,是天一觀的道長(zhǎng)宴倍。 經(jīng)常有香客問(wèn)我,道長(zhǎng)仓技,這世上最難降的妖魔是什么鸵贬? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮脖捻,結(jié)果婚禮上阔逼,老公的妹妹穿的比我還像新娘。我一直安慰自己地沮,他們只是感情好嗜浮,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著摩疑,像睡著了一般危融。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上未荒,一...
    開(kāi)封第一講書(shū)人閱讀 52,441評(píng)論 1 310
  • 那天专挪,我揣著相機(jī)與錄音,去河邊找鬼片排。 笑死寨腔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的率寡。 我是一名探鬼主播迫卢,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼冶共!你這毒婦竟也來(lái)了乾蛤?” 一聲冷哼從身側(cè)響起每界,我...
    開(kāi)封第一講書(shū)人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎家卖,沒(méi)想到半個(gè)月后眨层,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡上荡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年趴樱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酪捡。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叁征,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出逛薇,到底是詐尸還是另有隱情捺疼,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布永罚,位于F島的核電站啤呼,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏尤蛮。R本人自食惡果不足惜媳友,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望产捞。 院中可真熱鬧醇锚,春花似錦、人聲如沸坯临。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)看靠。三九已至赶促,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間挟炬,已是汗流浹背鸥滨。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谤祖,地道東北人婿滓。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像粥喜,于是被迫代替她去往敵國(guó)和親凸主。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

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