国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

從一個Demo開始,揭開Netty的神秘面紗

開發 前端
到目前為止,我們已經從I/O模型出發,逐步接觸到了Netty框架。這個過程中,基本解答了Netty是什么、為什么使用Netty等前置問題。給我們學習Netty提供了最原始的背景知識。

[[394009]]

本文轉載自微信公眾號「阿丸筆記」,作者阿丸筆記。轉載本文請聯系阿丸筆記公眾號。

上一篇文章我們對于I/O多路復用、Java NIO包 和 Netty 的關系有了全面的認識。

到目前為止,我們已經從I/O模型出發,逐步接觸到了Netty框架。這個過程中,基本解答了Netty是什么、為什么使用Netty等前置問題。給我們學習Netty提供了最原始的背景知識。

有了這些做基礎,下面我們可以開始慢慢去揭開Netty的神秘面紗了。

本文預計閱讀時間約 5分鐘,將重點圍繞以下幾個問題展開:

  • 如何用Netty編寫一個Server端服務Demo
  • 從Demo看Netty的邏輯架構,初識各個組件

1.編寫一個Server端Demo

1.1 基于主從Reactor模式的Demo實現

如果從來沒用過Netty,那么了解一下用Netty編寫的Server端Demo是必不可少的。

還記得我們上一篇說的 “主從Reactor模式” 嗎?可以構建兩個 Reactor,主 Reactor 單獨監聽server socket,accept新連接,然后將建立的 SocketChannel 注冊給指定的從 Reactor,從Reactor再執行事件的讀寫、分發,把業務處理就扔給worker線程池完成。

我們就按照這個模式,用Netty編寫一個服務端程序吧。

直接上代碼!

一個簡單的自定義ChannelHandler類,用來自定義業務處理邏輯:

一個包含Bootstrap的服務端啟動類:

  1. public class EchoServer { 
  2.     private int port; 
  3.  
  4.     public EchoServer(int port) { 
  5.         this.port = port; 
  6.     } 
  7.  
  8.     public static void main(String[] args) throws Exception { 
  9.         new EchoServer(8833).start(); 
  10.     } 
  11.  
  12.     public void start() throws Exception { 
  13.         //1.Reactor模型的主、從多線程 
  14.         EventLoopGroup mainGroup = new NioEventLoopGroup(); 
  15.         EventLoopGroup childGroup = new NioEventLoopGroup(); 
  16.  
  17.         try { 
  18.             //2.構造引導器實例ServerBootstrap 
  19.             ServerBootstrap b = new ServerBootstrap(); 
  20.             b.group(mainGroup, childGroup) 
  21.                     .channel(NioServerSocketChannel.class) //2.1 設置NIO的channel 
  22.                     .localAddress(new InetSocketAddress(port)) //2.2 配置本地監聽端口 
  23.                     .childHandler(new ChannelInitializer<SocketChannel>() { //2.3 初始化channel的時候,配置Handler 
  24.                         @Override 
  25.                         protected void initChannel(final SocketChannel socketChannel) { 
  26.                             socketChannel.pipeline() 
  27.                                     .addLast("codec", new HttpServerCodec()) 
  28.                                     .addLast("compressor", new HttpContentCompressor()) 
  29.                                     .addLast("aggregator", new HttpObjectAggregator(65536)) 
  30.                                     .addLast("handler", new EchoServerHandler()); //2.4 加入自定義業務邏輯ChannelHandler 
  31.                         } 
  32.                     }); 
  33.             ChannelFuture f = b.bind().sync(); //3.啟動監聽 
  34.             System.out.println("Http Server started, Listening on " + port); 
  35.             f.channel().closeFuture().sync(); 
  36.         } finally { 
  37.             mainGroup.shutdownGracefully().sync(); 
  38.             childGroup.shutdownGracefully().sync(); 
  39.         } 
  40.     } 

啟動后,通過curl調用,得到響應。

Demo完成了!

對于之前覺得用Java NIO包實現起來很復雜的的 “主從Reactor模式” ,用Netty簡簡單單就完成了。

只需要創建兩個EventLoopGroup,然后綁定到引導器ServerBootstrap上就好了.

mainGroup 是主 Reactor,childGroup 是從 Reactor。它們分別使用不同的 NioEventLoopGroup,主 Reactor 負責處理 Accept,然后把 Channel 注冊到從 Reactor 上,從 Reactor 主要負責 Channel 生命周期內的所有 I/O 事件。

1.2 Demo分析

從上面的Demo代碼可以看出,對于所有用Netty編寫的服務端程序,至少需要兩個部分:

  • 至少一個ChannelHandler
  • Bootstrapping

1)ChannelHandler

這個組件用來實現對客戶端發送過來的數據進行處理,可能包括編解碼、自定義業務邏輯處理等等。

對于ChannelHandler來說,有非常多的實現。在Demo中我們簡單使用了幾個Netty自帶的Handler,包括HttpServerCodec、HttpContentCompressor、HttpObjectAggregator,也使用了一個自定義的EchoServerHandler。

可以看到,對于Handler的使用,是非常重要也是非常方便的一個環節。我們會在以后的文章中詳細展開。

2)Bootstrapping

啟動代碼部分。用來配置服務端的啟動參數,包括監聽端口、服務端線程池配置、網絡連接屬性配置、ChannelHandler配置等等。

結合Demo來看,主要分為這幾個步驟:

  • 創建一個ServerBootstrap實例,用來引導啟動。
  • 創建一個(當我們使用主從Reactor模式時,需要創建兩個)NioEventLoopGroup實例來處理事件, 比如接受一個新的客戶端連接、讀寫數據等。
  • 指定一個端口,用來作為服務端的監聽端口。
  • 使用一系列channelHandler來初始化每個Channel,包括自定義業務邏輯實現的channelHandler。
  • 調用ServerBootstrap.bind() 來真正觸發啟動。

2. Netty的邏輯架構

通過上面的Demo演示,我們對 Netty 的使用已經有了一個大概的印象。

下面,我們根據Demo中使用的幾個組件,一起梳理一下 Netty 的邏輯架構。

結合我們的Demo和這個邏輯架構圖,我們梳理下各個組件的流轉過程:

  • 服務端利用ServerBootstrap進行啟動引導,綁定監聽端口
  • 啟動初始化時有 main EventLoopGroup 和 child EventLoopGroup 兩個組件,其中 main EventLoopGroup負責監聽網絡連接事件。當有新的網絡連接時,就將 Channel 注冊到 child EventLoopGroup。
  • child EventLoopGroup 會被分配一個 EventLoop 負責處理該 Channel 的讀寫事件。
  • 當客戶端發起 I/O 讀寫事件時,服務端 EventLoop 會進行數據的讀取,然后通過 ChannelPipeline 依次有序觸發各種ChannelHandler進行數據處理。
  • 客戶端數據會被依次傳遞到 ChannelPipeline 的 ChannelInboundHandler 中,在一個handler中處理完后就會傳入下一個handler。
  • 當數據寫回客戶端時,會將處理結果依次傳遞到 ChannelPipeline 的 ChannelOutboundHandler 中,在一個handler中處理完后就會傳入下一個handler,最后返回客戶端。

以上便是 Netty 各個組件的邏輯架構,我們暫時只需要了解個大致框架即可,后面我們會詳細介紹各個組件。

有幾個比較常見的問題在這里總結下:

1)什么是Channel

Channel 的字面意思是“通道”,它是網絡通信的載體,提供了基本的 API 用于網絡 I/O 操作,如 register、bind、connect、read、write、flush 等。

Netty 實現的 Channel 是以 JDK NIO Channel 為基礎的,提供了更高層次的抽象,屏蔽了底層 Socket。

2)什么是ChannleHandler和ChannelPipeline

ChannelHandler實現對客戶端發送過來的數據進行處理,可能包括編解碼、自定義業務邏輯處理等等。

ChannelPipeline 負責組裝各種 ChannelHandler,當 I/O 讀寫事件觸發時,ChannelPipeline 會依次調用 ChannelHandler 列表對 Channel 的數據進行攔截和處理。

3)什么是EventLoopGroup?

EventLoopGroup 本質是一個線程池, 是 Netty Reactor 線程模型的具體實現方式,主要負責接收 I/O 請求,并分配線程執行處理請求。我們在demo中使用了它的實現類 NioEventLoopGroup,也是 Netty 中最被推薦使用的線程模型。

我們還通過構建main EventLoopGroup 和 child EventLoopGroup 實現了 “主從Reactor模式”。

4)EventLoopGroup、EventLoop、Channel有什么關系?

一個 EventLoopGroup 往往包含一個或者多個 EventLoop。

EventLoop 用于處理 Channel 生命周期內的所有 I/O 事件,如 accept、connect、read、write 等 I/O 事件。

EventLoop 同一時間會與一個線程綁定,每個 EventLoop 負責處理多個 Channel。

參考書目:

 

《Netty in Action》

 

責任編輯:武曉燕 來源: 阿丸筆記
相關推薦

2015-08-20 13:43:17

NFV網絡功能虛擬化

2021-06-07 08:18:12

云計算云端阿里云

2010-05-17 09:13:35

2014-03-12 11:11:39

Storage vMo虛擬機

2010-05-26 19:12:41

SVN沖突

2018-03-01 09:33:05

軟件定義存儲

2009-06-01 09:04:44

Google WaveWeb

2024-11-11 16:36:41

2016-04-06 09:27:10

runtime解密學習

2009-09-15 15:34:33

Google Fast

2023-11-02 09:55:40

2015-09-06 10:54:29

HTTP網絡協議

2025-01-07 15:07:13

2024-02-14 09:00:00

機器學習索引ChatGPT

2016-11-16 09:06:59

2020-09-27 08:02:47

操作系統

2010-05-11 10:19:17

VMforceJava云計算

2017-10-16 05:56:00

2021-09-17 15:54:41

深度學習機器學習人工智能

2021-07-28 21:49:01

JVM對象內存
點贊
收藏

51CTO技術棧公眾號

国产亚洲美女精品久久久| 日韩成人动漫| 久久这里有精品视频| 久久影视精品| 国产精品www色诱视频| 国产精品视频网站| 色999五月色| av观看免费在线| 中文字幕校园春色| 欧美女同一区| 99久久久久国产精品| 成人免费视频视频| 日韩三级av在线播放| 日本乱人伦a精品| 国精产品一区一区三区视频| av资源网在线播放| 国产精品视区| 欧美人与z0zoxxxx视频| 色婷婷av一区二区三区久久| 欧美精品中文字幕一区| 九九热这里只有精品免费看| 五月天综合婷婷| 户外露出一区二区三区| av色综合久久天堂av综合| 日韩视频第一页| 天堂…中文在线最新版在线| 黑人久久a级毛片免费观看| 日韩欧美在线观看视频| 一区二区免费在线观看| 一区二区三区亚洲变态调教大结局 | 91麻豆精品国产91久久久久久久久| 91免费观看网站| avove在线观看| 全色精品综合影院| 最新亚洲精品| 麻豆精品久久精品色综合| 日本 国产 欧美色综合| 日韩欧美高清视频| 午夜精品久久久久久久99热| 国产96在线 | 亚洲| 牛牛影视久久网| 成人精品视频在线| 91大神在线播放精品| wwwwww99| 欧美一区二区麻豆红桃视频| 亚洲一区日韩精品中文字幕| 午夜精品一区二区三区在线视频 | 米奇777在线影院线| 久久综合色占| 精品一区二区三区四区五区| 亚洲色欲色欲www在线观看| 国产成人在线一区| 欧洲亚洲在线| 国内精品伊人久久久久影院对白| 另类色图亚洲色图| 午夜伦伦电影理论片费看| 清纯唯美综合亚洲| 黑人巨大精品欧美一区二区免费| 天天人人精品| 国产精品xx| 99久精品国产| 欧美中文在线字幕| 欧美xxx黑人xxx水蜜桃| 美女高潮久久久| 45www国产精品网站| 成年人视频网站在线| 久久久亚洲国产美女国产盗摄| 狼狼综合久久久久综合网| 秋霞午夜一区二区三区视频| 欧美一区二区三区在线视频| 天天爱天天操天天干| 午夜在线精品偷拍| 国产精品一区二区3区| 99精品视频在线免费播放| 亚洲婷婷在线| 日韩精品在线电影| 欧美18一12sex性处hd| 亚洲免费网址| 琪琪亚洲精品午夜在线| 日韩精品影院| 欧美日韩高清一区| mm1313亚洲国产精品无码试看| 欧美gayvideo| 美女撒尿一区二区三区| 午夜小视频在线| 国产精品一区二区久久不卡| 国产精品第3页| 日本超碰一区二区| 亚洲色图国产精品| 成码无人av片在线观看网站| 91农村精品一区二区在线| 欧美国产综合视频| 欧美午夜18电影| 国产婷婷成人久久av免费高清 | 亚洲精品观看| 色妞久久福利网| 黄页视频在线观看| 亚洲精品在线观看91| 亚洲黄一区二区三区| 欧美在线日韩在线| 一级黄色特级片| 日韩福利在线观看| 久久久亚洲午夜电影| 国产91在线高潮白浆在线观看 | 亚洲综合最新在线| 91综合久久爱com| xvideos亚洲人网站| 丁香久久综合| 亚洲精品二三区| av午夜在线观看| 精品欧美一区二区在线观看 | 亚洲欧美清纯在线制服| 国产91九色视频| 成人免费在线电影网| 欧美精品激情在线| 青青在线精品| xxxx性欧美| 综合久草视频| 精品中文字幕在线| 精品久久国产一区| 日韩精品一区二区三区老鸭窝| 国产乱子伦三级在线播放| 欧美日韩国产小视频| av中文在线| 精品成人免费观看| 欧美电影在线观看网站| 久久久久www| crdy在线观看欧美| 国产成人精品一区二区| 亚洲伊人伊成久久人综合网| 欧美人交a欧美精品| 欧美成人自拍| 欧美另类高清视频在线| 成人免费观看男女羞羞视频| 成人久久久久久久久| 玉足女爽爽91| av大片在线播放| 不卡视频免费播放| 好男人看片在线观看免费观看国语 | 亚洲欧美福利视频| 国产一区二区三区亚洲综合| 九九热最新视频//这里只有精品 | 国产成人亚洲精品| 在线综合欧美| 俄罗斯av网站| 亚洲欧洲av色图| 日本私人网站在线观看| 7777精品伊人久久久大香线蕉经典版下载| 成人福利免费网站| 久久精品国产一区二区三| 777精品久无码人妻蜜桃| 久久久久国产精品麻豆ai换脸 | 国产欧美 在线欧美| 欧美日韩一区二区三区电影| 国产一区二区在线观看免费播放| 国产在线看片免费视频在线观看| 无码少妇一区二区三区| 在线播放91灌醉迷j高跟美女 | 午夜在线播放视频欧美| 中文字幕在线亚洲精品| 欧美舌奴丨vk视频| 成人丝袜视频网| caoporn成人免费视频在线| 亚洲一区免费在线观看| 亚洲色无码播放| 又黄又免费的网站| 欧美妇女性影城| 在线成人激情黄色| 影音先锋久久久| av成人午夜| 精品动漫3d一区二区三区免费| 水蜜桃亚洲精品| 日本一区二区三区四区在线视频| 激情内射人妻1区2区3区 | 性色av一区| 亚洲大胆人体大胆做受1| 麻豆视频成人| 欧美丝袜丝nylons| 青青青免费在线视频| 国产精品一区二区三区在线播放 | 成人免费在线观看| 少妇视频在线观看| 99一区二区三区| 国产一区二区三区日韩| 外国成人激情视频| 免费成人在线观看视频| 色综合久久中文| 精品一区二区三区中文字幕视频| 国产日产亚洲精品| 三级欧美在线一区| 亚洲国产精品成人一区二区在线| 欧美主播福利视频| 久久九九国产| 国产一区二区在线免费播放| 亚洲成人免费在线观看| bl在线肉h视频大尺度| 国产精品国产精品国产专区不卡| 高清视频一区二区| 在线观看黄色| 色综合天天综合网国产成人网|