Netty剖析 - 3. 总结

前言

本篇为《Netty剖析》系列最后一篇,主要对Netty做简单的总结,如果对Netty的细节感兴趣,可以阅读本系列的另外两篇:

Netty适用场景

Netty只是一套网络框架,它不可能适用于所有场景,所以选用Netty前最好能想清楚它是否能很好的应对自己的需求。想要知道Netty的适用场景最好的方式就是从Netty本身的特性出发进行思考,具体可参考本系列第一篇Netty剖析 - 1. 基础中"Netty的特色"章节,基于此,如果你的需求属于下列场景,则Netty会比较适合你,包括:

  • 高并发,实时处理,如:游戏服务器,聊天服务器,SOA调用框架,RPC框架等
  • 对网络协议(传输层与应用层)有一定的定制需求
  • 一套代码可能需要同时支持BIO和NIO

而其他情况,Netty并一不定适合,如:

  • 需求较简单的网络应用,则不必使用Netty,毕竟在能满足需求的基础上,越简单越好
  • 单次请求处理耗时较长的应用,这种情况下NIO没有优势,此时使用BIO的方式可能效果会更好

Netty支持的协议

Netty框架本身已经对常用的协议进行了实现,包括:

  • 应用层:HTTP,WebSocket,HTTP2,Redis,SMTP,DNS,MQTT,SSL,STARTTLS ,RTSP
  • 传输层:TCP,UDP,SCTP,UDT等
  • 其他:Protobuf,gzip

可以说,一般的应用使用Netty本身的支持就能满足大部分需求,剩下的关注自己的业务即可

Netty & MINA & Jetty

Netty和MINA经常会放在一起比较,主要是因为两个框架有很多相似的地方,或者说它们本身就是一对兄弟 -- 都是基于Java NIO封装的一个网络框架。其实更深入的了解会发现,Netty的作者Trustin Lee也是MINA的作者(当然已经不继续参与了),据说他是对MINA的代码不满意,才重新写了Netty,所以看Netty的代码经常能看到MINA的影子,但就现在来说Netty的社区远比MINA要活跃,迭代频率也更高,大部分的特性也优于MINA

至于Jetty之所以会拿来比较,主要是因为和Netty名字类似,但其实这两者并没有很大的可比性,因为Jetty是一个轻量级的servlet容器,而Netty是一个基于NIO的异步网络编程框架,基于Netty可以实现自己的servlet容器或者其它网络应用

相关项目

很多项目内部都使用Netty作为其网络处理模块,包括:

总结

本系列主要针对Netty的基础概念,框架结构及特色机制做了浅显的分析,由于本人水平有限,难免有错误和不合适的地方,望大家不吝指出。Netty本身是一个优秀的框架,其源码的层次和结构也很清晰,值得一读;平常很多人说熟悉网络,但是大部分人也仅仅只是知道一些皮毛(也包括我自己),其实,想要写一个健壮易用的网络框架并不容易,如果需要同时支持高并发,那更是难上加难,而Netty在这一点就做得很出色,不仅体现在其本身优秀的代码组织,更多的还是把一些已有的功能和思想进行合适的组装和适当的优化。另外,结合当今另一个炙手可热的高性能服务器Nginx会发现,这两者的思想有很多相通之处,如都是基于事件机制,都分为主工作组与子工作组,都是在PipeLine上设置一系列的Handler进行数据处理,都有通过逻辑映射增强内存效率的设计等等,很有意思,感兴趣的小伙伴可以找寻相关资料进行深入研究

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容

  • Netty的简单介绍 Netty 是一个 NIO client-server(客户端服务器)框架,使用 Netty...
    AI乔治阅读 8,338评论 1 101
  • 作者:李林锋 原文:http://www.infoq.com/cn/articles/netty-high-per...
    杨鑫科阅读 3,928评论 0 64
  • 前言 在了解一个事物之前,最好能对它的基本属性和相关概念有个基本的认知,所以学习Netty之前,也有必要了解与Ne...
    简xiaoyao阅读 1,685评论 0 10
  • 八个月以前你刚刚出世, 我欣喜的像个大孩子。 你圆圆鼓鼓的小肚子, 装满了未曾谋面的故事。 还记得第一次换尿不湿,...
    琪宝她爹丶阅读 193评论 0 4
  • 阿诚快速的拿起包离开办公室,然后他似乎觉得有些不太恰当,就重新开门把皮包随手放回到沙发上。在楼道里,短短的距离,他...
    三石三味阅读 241评论 4 20