Reactor的NIO線程模型

1.Reactor單線程模型

傳統(tǒng)的javaNIO通信的線程模型甸各。該線程模型僅有一個(gè)I/O線程處理所有的I/O操作姑曙,如下圖:

單線程模型的Reactor

所有的客戶端都連接到一個(gè)I/O線程負(fù)責(zé)的Acceptor上,連接成功后,由Reactor里的Dispatch將接收的ByteBuffer分發(fā)到指定的Handler上處理,進(jìn)行解碼,業(yè)務(wù)處理充蓝,編碼及發(fā)送給客戶端等過程。整個(gè)過程I/O線程都是異步非阻塞方式實(shí)現(xiàn)喉磁。

I/O線程完成的工作:

1)服務(wù)端NIO線程用于監(jiān)聽客戶端連接

2)客戶端NIO線程用于向服務(wù)器端發(fā)送連接請(qǐng)求

3)客戶端和服務(wù)端的讀寫操作

不足:

1)如果客戶端同時(shí)有成百上千的請(qǐng)求谓苟,會(huì)導(dǎo)致I/O線程不停的工作,CPU利用率負(fù)荷超載协怒,同時(shí)造成很多客戶端超時(shí)得不到響應(yīng)

2)一旦I/O線程出現(xiàn)異常涝焙,可能會(huì)導(dǎo)致所有客戶端掉線,造成系統(tǒng)單點(diǎn)故障

2.多線程的Reactor模型

多線程模型采用1個(gè)線程接收客戶端請(qǐng)求孕暇,同時(shí)使用1個(gè)線程池處理讀寫等操作仑撞。模型如下:

多線程的Reactor

其中Acceptor單線程用于監(jiān)聽及接收client的連接請(qǐng)求,連接成功后會(huì)將這些連接注冊(cè)到WorkThreadPool(工作線程池)的其中一個(gè)線程上妖滔,由工作線程池分出1個(gè)工作線程用于和該client的讀寫隧哮、編碼、解碼操作座舍。一個(gè)client只能和一個(gè)工作線程對(duì)應(yīng)沮翔,不能注冊(cè)到多個(gè)工作線程,防止出現(xiàn)并發(fā)操作問題曲秉。

WorkThreadPool由一個(gè)任務(wù)隊(duì)列和N個(gè)線程組成采蚀,client連接成功后的讀寫請(qǐng)求都會(huì)放到任務(wù)隊(duì)列中,工作線程池會(huì)從任務(wù)隊(duì)列中獲取任務(wù)承二、分配線程進(jìn)行處理搏存。

注意:這里的工作線程并不是業(yè)務(wù)處理線程,工作線程只是負(fù)責(zé)業(yè)務(wù)線程處理前或者業(yè)務(wù)線程處理后的讀寫和編解碼操作矢洲。比如解碼成功后獲取對(duì)應(yīng)的消息內(nèi)容后璧眠,對(duì)這些消息的處理是由單獨(dú)的業(yè)務(wù)線程處理的,當(dāng)然業(yè)務(wù)線程一般也是有自己的線程池。

不足:?jiǎn)为?dú)的Acceptor線程會(huì)成為系統(tǒng)的瓶頸责静,一旦出現(xiàn)問題袁滥,后面的工作線程池也無法工作。

3.主從Reactor模型

該模型是的Acceptor由一個(gè)線程池MainReactorThreadPool負(fù)責(zé)監(jiān)聽和接收client的連接灾螃、認(rèn)證等题翻,同時(shí)由另一個(gè)SubReactorThreadPool線程池負(fù)責(zé)讀寫、編碼等工作腰鬼。模型如下:

主從Reactor模型

該模型可以有效解決Acceptor單線程瓶頸問題嵌赠,同時(shí)能提高客戶端并發(fā)能力,穩(wěn)定性和處理效率高熄赡。

Netty支持上面三種不同的線程模型姜挺,針對(duì)不同的業(yè)務(wù)需求可以設(shè)置不同的啟動(dòng)參數(shù),選擇對(duì)應(yīng)的線程模型彼硫,不過netty官網(wǎng)推薦使用第三種主從模式炊豪。

參考:https://www.cnblogs.com/ivaneye/p/5731432.html

http://blog.csdn.net/yexin94822739/article/details/73334006

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拧篮,隨后出現(xiàn)的幾起案子词渤,更是在濱河造成了極大的恐慌,老刑警劉巖串绩,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缺虐,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡礁凡,警方通過查閱死者的電腦和手機(jī)高氮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來把篓,“玉大人,你說我怎么就攤上這事腰涧∪脱冢” “怎么了?”我有些...
    開封第一講書人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵窖铡,是天一觀的道長(zhǎng)疗锐。 經(jīng)常有香客問我,道長(zhǎng)费彼,這世上最難降的妖魔是什么滑臊? 我笑而不...
    開封第一講書人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮箍铲,結(jié)果婚禮上雇卷,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好关划,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開白布小染。 她就那樣靜靜地躺著,像睡著了一般贮折。 火紅的嫁衣襯著肌膚如雪裤翩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,624評(píng)論 1 305
  • 那天调榄,我揣著相機(jī)與錄音踊赠,去河邊找鬼。 笑死每庆,一個(gè)胖子當(dāng)著我的面吹牛筐带,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播扣孟,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼烫堤,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了凤价?” 一聲冷哼從身側(cè)響起鸽斟,我...
    開封第一講書人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎利诺,沒想到半個(gè)月后富蓄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡慢逾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年立倍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片侣滩。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡口注,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出君珠,到底是詐尸還是另有隱情寝志,我是刑警寧澤,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布策添,位于F島的核電站材部,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏唯竹。R本人自食惡果不足惜乐导,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望浸颓。 院中可真熱鬧物臂,春花似錦旺拉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至泽本,卻和暖如春淘太,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背规丽。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工蒲牧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赌莺。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓冰抢,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親艘狭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子挎扰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355