欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于NIO的Netty網(wǎng)絡框架(詳解)

 更新時間:2017年06月09日 08:31:13   投稿:jingxian  
下面小編就為大家?guī)硪黄贜IO的Netty網(wǎng)絡框架(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

Netty是一個高性能、異步事件驅(qū)動的NIO框架,它提供了對TCP、UDP和文件傳輸?shù)闹С郑琋etty的所有IO操作都是異步非阻塞的,通過Future-Listener機制,用戶可以方便的主動獲取或者通過通知機制獲得IO操作結(jié)果。

Netty的優(yōu)點有:

a、功能豐富,內(nèi)置了多種數(shù)據(jù)編解碼功能、支持多種網(wǎng)絡協(xié)議。

b、高性能,通過與其它主流NIO網(wǎng)絡框架對比,它的綜合性能最佳。

c、可擴展性好,可通過它提供的ChannelHandler組件對網(wǎng)絡通信方面進行靈活擴展。

d、易用性,API使用簡單。

e、經(jīng)過了許多商業(yè)應用的考驗,在互聯(lián)網(wǎng)、網(wǎng)絡游戲、大數(shù)據(jù)、電信軟件等眾多行業(yè)得到成功商用。

Netty采用了典型的三層網(wǎng)絡架構(gòu)進行設計,邏輯架構(gòu)圖如下:

第一層:Reactor通信調(diào)度層。該層的主要職責就是監(jiān)聽網(wǎng)絡的連接和讀寫操作,負責將網(wǎng)絡層的數(shù)據(jù)讀取到內(nèi)存緩沖區(qū)中,然后觸發(fā)各種網(wǎng)絡事件,例如連接創(chuàng)建、連接激活、讀事件、寫事件等,將這些事件觸發(fā)到Pipeline中,再由Pipeline充當?shù)穆氊熸渷磉M行后續(xù)的處理。

第二層:職責鏈Pipeline層。負責事件在職責鏈中有序的向前(后)傳播,同時負責動態(tài)的編排職責鏈。Pipeline可以選擇監(jiān)聽和處理自己關(guān)心的事件。

第三層:業(yè)務邏輯處理層,一般可分為兩類:a. 純粹的業(yè)務邏輯處理,例如日志、訂單處理。b. 應用層協(xié)議管理,例如HTTP(S)協(xié)議、FTP協(xié)議等。

我們都知道影響網(wǎng)絡服務通信性能的主要因素有:網(wǎng)絡I/O模型、線程(進程)調(diào)度模型和數(shù)據(jù)序列化方式。

在網(wǎng)絡I/O模型方面,Netty采用基于非阻塞I/O的實現(xiàn),底層依賴的是JDKNIO框架的Selector。

在線程調(diào)度模型方面,Netty采用Reactor線程模型。常用的Reactor線程模型有三種,分別是:

a、Reactor單線程模型:Reactor單線程模型,指的是所有的I/O操作都在同一個NIO線程上面完成。對于一些小容量應用場景,可以使用單線程模型。

b、Reactor多線程模型:Rector多線程模型與單線程模型最大的區(qū)別就是有一組NIO線程處理I/O操作。主要用于高并發(fā)、大業(yè)務量場景。

c、主從Reactor多線程模型:主從Reactor線程模型的特點是服務端用于接收客戶端連接的不再是一個單獨的NIO線程,而是一個獨立的NIO線程池。利用主從NIO線程模型,可以解決一個服務端監(jiān)聽線程無法有效處理所有客戶端連接的性能不足問題。Netty線程模型并非固定不變的,它可以支持三種Reactor線程模型。

在數(shù)據(jù)序列化方面,影響序列化性能的主要因素有:

a、序列化后的碼流大?。ňW(wǎng)絡帶寬占用)。

b、序列化和反序列化操作的性能(CPU資源占用)。

c、并發(fā)調(diào)用時的性能表現(xiàn):穩(wěn)定性、線性增長等。

Netty默認提供了對GoogleProtobuf二進制序列化框架的支持,但通過擴展Netty的編解碼接口,可以實現(xiàn)其它的高性能序列化框架,例如Avro、Thrift的壓縮二進制編解碼框架。

以上這篇基于NIO的Netty網(wǎng)絡框架(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring事務原理解析

    Spring事務原理解析

    Spring事務有可能會提交,回滾、掛起、恢復,所以Spring事務提供了一種機制,可以讓程序員來監(jiān)聽當前Spring事務所處于的狀態(tài),這篇文章主要介紹了Spring底層事務原理,需要的朋友可以參考下
    2022-12-12
  • Java NIO ByteBuffer讀取文件方式

    Java NIO ByteBuffer讀取文件方式

    這篇文章主要介紹了Java NIO ByteBuffer讀取文件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 詳解springboot+mybatis多數(shù)據(jù)源最簡解決方案

    詳解springboot+mybatis多數(shù)據(jù)源最簡解決方案

    本篇文章主要介紹了詳解springboot+mybatis多數(shù)據(jù)源最簡解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 使用springMVC所需要的pom配置

    使用springMVC所需要的pom配置

    這篇文章主要介紹了使用springMVC所需要的pom配置,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • spring data jpa 創(chuàng)建方法名進行簡單查詢方式

    spring data jpa 創(chuàng)建方法名進行簡單查詢方式

    這篇文章主要介紹了spring data jpa 創(chuàng)建方法名進行簡單查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • java實現(xiàn)時間控制的幾種方案

    java實現(xiàn)時間控制的幾種方案

    這篇文章主要介紹了java實現(xiàn)時間控制的幾種方案,本文從多個方面給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • RocketMQ消息發(fā)送與消息類別詳解

    RocketMQ消息發(fā)送與消息類別詳解

    這篇文章主要介紹了RocketMQ消息發(fā)送與消息類別詳解,事務消息的生產(chǎn)者執(zhí)行本地事務,并根據(jù)事務執(zhí)行的結(jié)果選擇是否提交或回滾事務,
    如果事務執(zhí)行成功并選擇提交事務,則產(chǎn)生注冊成功消息,進入下一步,需要的朋友可以參考下
    2023-09-09
  • Java重寫與重載之間的區(qū)別

    Java重寫與重載之間的區(qū)別

    本文主要介紹了Java重寫與重載之間的區(qū)別。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • OpenFeign調(diào)用服務請求頭丟失Token的解決

    OpenFeign調(diào)用服務請求頭丟失Token的解決

    這篇文章主要介紹了OpenFeign調(diào)用服務請求頭丟失Token的解決方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java線程實現(xiàn)時間動態(tài)顯示

    Java線程實現(xiàn)時間動態(tài)顯示

    這篇文章主要為大家詳細介紹了Java線程實現(xiàn)時間動態(tài)顯示,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04

最新評論