Netty學習前置知識

IO編程

java BIO

網(wǎng)絡編程的基本模型是基于服務器/客戶端喉酌,二者通過三次握手來連接逻卖,并通過socket通信履腋。采用BIO通信模型的服務端帖蔓,通常由一個獨立的Acceptor線程負責監(jiān)聽客戶端的連接企软,在接收到客戶端請求后創(chuàng)建一個單獨的線程與服務器交互庐扫,通過輸出流將結(jié)果返回給客戶端,線程銷毀仗哨。
缺點:缺乏彈性伸縮能力形庭。在高并發(fā)的情況下客戶端進程與服務端進程保持1:1,占用大量系統(tǒng)資源厌漂。

偽異步IO

為了改進這種一連接一線程的模型萨醒,我們可以使用線程池來管理這些線程,實現(xiàn)1個或多個線程處理N個客戶端的模型(但是底層還是使用的同步阻塞I/O)桩卵,通常被稱為“偽異步I/O模型“验靡。
我們知道倍宾,如果使用CachedThreadPool線程池,其實除了能自動幫我們管理線程(復用)胜嗓,看起來也就像是1:1的客戶端:線程數(shù)模型高职,而使用FixedThreadPool我們就有效的控制了線程的最大數(shù)量,保證了系統(tǒng)有限的資源的控制辞州,實現(xiàn)了N:M的偽異步I/O模型怔锌。
但是,正因為限制了線程數(shù)量变过,如果發(fā)生大量并發(fā)請求埃元,超過最大數(shù)量的線程就只能等待,直到線程池中的有空閑的線程可以被復用媚狰。而對Socket的輸入流就行讀取時岛杀,會一直阻塞,直到發(fā)生:

  • 有數(shù)據(jù)可讀
  • 可用數(shù)據(jù)以及讀取完畢
  • 發(fā)生空指針或I/O異常
    所以在讀取數(shù)據(jù)較慢時(比如數(shù)據(jù)量大崭孤、網(wǎng)絡傳輸慢等)类嗤,大量并發(fā)的情況下,其他接入的消息辨宠,只能一直等待遗锣,這就是最大的弊端。

NIO和AIO

NIO

一般稱非阻塞IO嗤形,提供了兩種新的套接字通道SocketChannel和ServerSocketChannel精偿。對于低負載使用同步阻塞可以提升開發(fā)效率和可維護性,對于高并發(fā)應使用NIO

  • 緩沖區(qū) buffer 實際上是一個數(shù)組赋兵,數(shù)據(jù)的讀入和寫入都通過它
  • 通道 channel 區(qū)別于流 全雙工 同時讀寫
  • 多路復用器 selector可以不斷輪詢注冊在其上的channel笔咽,如果該channel上發(fā)生讀寫,則可以通過selectorKey獲得通道上的數(shù)據(jù)霹期,進行I/O操作
    %NODE_PATH%\bin;
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末拓轻,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子经伙,更是在濱河造成了極大的恐慌,老刑警劉巖勿锅,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帕膜,死亡現(xiàn)場離奇詭異,居然都是意外死亡溢十,警方通過查閱死者的電腦和手機垮刹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來张弛,“玉大人荒典,你說我怎么就攤上這事酪劫。” “怎么了寺董?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵覆糟,是天一觀的道長。 經(jīng)常有香客問我遮咖,道長滩字,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任御吞,我火速辦了婚禮麦箍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘陶珠。我一直安慰自己挟裂,他們只是感情好,可當我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布揍诽。 她就那樣靜靜地躺著诀蓉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪寝姿。 梳的紋絲不亂的頭發(fā)上交排,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天,我揣著相機與錄音饵筑,去河邊找鬼埃篓。 笑死,一個胖子當著我的面吹牛根资,可吹牛的內(nèi)容都是我干的架专。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼玄帕,長吁一口氣:“原來是場噩夢啊……” “哼部脚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起裤纹,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤委刘,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鹰椒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锡移,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年漆际,在試婚紗的時候發(fā)現(xiàn)自己被綠了淆珊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡奸汇,死狀恐怖施符,靈堂內(nèi)的尸體忽然破棺而出往声,到底是詐尸還是另有隱情,我是刑警寧澤戳吝,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布浩销,位于F島的核電站,受9級特大地震影響骨坑,放射性物質(zhì)發(fā)生泄漏撼嗓。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一欢唾、第九天 我趴在偏房一處隱蔽的房頂上張望且警。 院中可真熱鬧,春花似錦礁遣、人聲如沸斑芜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杏头。三九已至,卻和暖如春沸呐,著一層夾襖步出監(jiān)牢的瞬間醇王,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工崭添, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留寓娩,地道東北人。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓呼渣,卻偏偏與公主長得像棘伴,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子屁置,可洞房花燭夜當晚...
    茶點故事閱讀 43,472評論 2 348

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