基于NIO的Netty網(wǎng)絡(luò)框架(詳解)
Netty是一個(gè)高性能、異步事件驅(qū)動(dòng)的NIO框架,它提供了對TCP、UDP和文件傳輸?shù)闹С?,Netty的所有IO操作都是異步非阻塞的,通過Future-Listener機(jī)制,用戶可以方便的主動(dòng)獲取或者通過通知機(jī)制獲得IO操作結(jié)果。

Netty的優(yōu)點(diǎn)有:
a、功能豐富,內(nèi)置了多種數(shù)據(jù)編解碼功能、支持多種網(wǎng)絡(luò)協(xié)議。
b、高性能,通過與其它主流NIO網(wǎng)絡(luò)框架對比,它的綜合性能最佳。
c、可擴(kuò)展性好,可通過它提供的ChannelHandler組件對網(wǎng)絡(luò)通信方面進(jìn)行靈活擴(kuò)展。
d、易用性,API使用簡單。
e、經(jīng)過了許多商業(yè)應(yīng)用的考驗(yàn),在互聯(lián)網(wǎng)、網(wǎng)絡(luò)游戲、大數(shù)據(jù)、電信軟件等眾多行業(yè)得到成功商用。
Netty采用了典型的三層網(wǎng)絡(luò)架構(gòu)進(jìn)行設(shè)計(jì),邏輯架構(gòu)圖如下:

第一層:Reactor通信調(diào)度層。該層的主要職責(zé)就是監(jiān)聽網(wǎng)絡(luò)的連接和讀寫操作,負(fù)責(zé)將網(wǎng)絡(luò)層的數(shù)據(jù)讀取到內(nèi)存緩沖區(qū)中,然后觸發(fā)各種網(wǎng)絡(luò)事件,例如連接創(chuàng)建、連接激活、讀事件、寫事件等,將這些事件觸發(fā)到Pipeline中,再由Pipeline充當(dāng)?shù)穆氊?zé)鏈來進(jìn)行后續(xù)的處理。
第二層:職責(zé)鏈Pipeline層。負(fù)責(zé)事件在職責(zé)鏈中有序的向前(后)傳播,同時(shí)負(fù)責(zé)動(dòng)態(tài)的編排職責(zé)鏈。Pipeline可以選擇監(jiān)聽和處理自己關(guān)心的事件。
第三層:業(yè)務(wù)邏輯處理層,一般可分為兩類:a. 純粹的業(yè)務(wù)邏輯處理,例如日志、訂單處理。b. 應(yīng)用層協(xié)議管理,例如HTTP(S)協(xié)議、FTP協(xié)議等。
我們都知道影響網(wǎng)絡(luò)服務(wù)通信性能的主要因素有:網(wǎng)絡(luò)I/O模型、線程(進(jìn)程)調(diào)度模型和數(shù)據(jù)序列化方式。
在網(wǎng)絡(luò)I/O模型方面,Netty采用基于非阻塞I/O的實(shí)現(xiàn),底層依賴的是JDKNIO框架的Selector。
在線程調(diào)度模型方面,Netty采用Reactor線程模型。常用的Reactor線程模型有三種,分別是:
a、Reactor單線程模型:Reactor單線程模型,指的是所有的I/O操作都在同一個(gè)NIO線程上面完成。對于一些小容量應(yīng)用場景,可以使用單線程模型。
b、Reactor多線程模型:Rector多線程模型與單線程模型最大的區(qū)別就是有一組NIO線程處理I/O操作。主要用于高并發(fā)、大業(yè)務(wù)量場景。
c、主從Reactor多線程模型:主從Reactor線程模型的特點(diǎn)是服務(wù)端用于接收客戶端連接的不再是一個(gè)單獨(dú)的NIO線程,而是一個(gè)獨(dú)立的NIO線程池。利用主從NIO線程模型,可以解決一個(gè)服務(wù)端監(jiān)聽線程無法有效處理所有客戶端連接的性能不足問題。Netty線程模型并非固定不變的,它可以支持三種Reactor線程模型。
在數(shù)據(jù)序列化方面,影響序列化性能的主要因素有:
a、序列化后的碼流大小(網(wǎng)絡(luò)帶寬占用)。
b、序列化和反序列化操作的性能(CPU資源占用)。
c、并發(fā)調(diào)用時(shí)的性能表現(xiàn):穩(wěn)定性、線性增長等。
Netty默認(rèn)提供了對GoogleProtobuf二進(jìn)制序列化框架的支持,但通過擴(kuò)展Netty的編解碼接口,可以實(shí)現(xiàn)其它的高性能序列化框架,例如Avro、Thrift的壓縮二進(jìn)制編解碼框架。
以上這篇基于NIO的Netty網(wǎng)絡(luò)框架(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot使用redis對單個(gè)對象進(jìn)行自動(dòng)緩存更新刪除的實(shí)現(xiàn)
本文主要介紹了springboot使用redis對單個(gè)對象進(jìn)行自動(dòng)緩存更新刪除的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
Maven profile實(shí)現(xiàn)不同環(huán)境的配置管理實(shí)踐
這篇文章主要介紹了Maven profile實(shí)現(xiàn)不同環(huán)境的配置管理實(shí)踐,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
一文帶你學(xué)會(huì)Spring?JDBC的使用
JDBC?就是?數(shù)據(jù)庫開發(fā)?操作的?代名詞,因?yàn)橹灰乾F(xiàn)代商業(yè)項(xiàng)目的開發(fā)那么一定是離不開?數(shù)據(jù)庫?的,不管你搞的是什么,只要是想使用動(dòng)態(tài)的開發(fā)結(jié)構(gòu),那么一定就是?JDBC?,那么下面來教教大家傳統(tǒng)JDBC的使用2022-09-09
Java GZip 基于內(nèi)存實(shí)現(xiàn)壓縮和解壓的方法
這篇文章主要介紹了Java GZip 基于內(nèi)存實(shí)現(xiàn)壓縮和解壓的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
程序包org.springframework.boot不存在的問題解決
本文主要介紹了程序包org.springframework.boot不存在的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09

