单独从性能角度,Netty在基础的NIO等类库之上进行了很多改进,例如:
总的来说,Netty并没有Java核心类库那些强烈的通用性、跨平台等各种负担,针对性能等特定目标以及Linux等特定环境,采取了一些极致的优化手段。
这是一个比较开放的问题,我给出的回答是个概要性的举例说明。面试官很可能利用这种开放问题作为引子,针对你回答的一个或者多个点,深入探讨你在不同层次上的理解程度。
在面试准备中,兼顾整体性的同时,不要忘记选定个别重点进行深入理解掌握,最好是进行源码层面的深入阅读和实验。如果你希望了解更多从性能角度Netty在编码层面的手段,可以参考Norman在Devoxx上的分享,其中的很多技巧对于实现极致性能的API有一定借鉴意义,但在一般的业务开发中要谨慎采用。
虽然提到Netty,人们会自然地想到高性能,但是Netty本身的优势不仅仅只有这一个方面,
下面我会侧重两个方面:
首先,我们从整体了解一下Netty。按照官方定义,它是一个异步的、基于事件Client/Server的网络框架,目标是提供一种简单、快速构建网络应用的方式,同时保证高吞吐量、低延时、高可靠性。
从设计思路和目的上,Netty与Java自身的NIO框架相比有哪些不同呢?
我们知道Java的标准类库,由于其基础性、通用性的定位,往往过于关注技术模型上的抽象,而不是从一线应用开发者的角度去思考。我曾提到过,引入并发包的一个重要原因就是,应用开发者使用Thread API比较痛苦,需要操心的不仅仅是业务逻辑,而且还要自己负责将其映射到Thread模型上。Java NIO的设计也有类似的特点,开发者需要深入掌握线程、IO、网络等相关概念,学习路径很长,很容易导致代码复杂、晦涩,即使是有经验的工程师,也难以快速地写出高可靠性的实现。
Netty的设计强调了 “ Separation Of Concerns”,通过精巧设计的事件机制,将业务逻辑和无关技术逻辑进行隔离,并通过各种方便的抽象,一定程度上填补了了基础平台和业务开发之间的鸿沟,更有利于在应用开发中普及业界的最佳实践。
另外, Netty > java.nio + java. net!
从API能力范围来看,Netty完全是Java NIO框架的一个大大的超集,你可以参考Netty官方的模块划分。
除了核心的事件机制等,Netty还额外提供了很多功能,例如:
可以看到,Netty的能力范围大大超过了Java核心类库中的NIO等API,可以说它是一个从应用视角出发的产物。
当然,对于基础API设计,Netty也有自己独到的见解,未来Java NIO API也可能据此进行一定的改进。
接下来,我们一起来看一个入门的代码实例,看看Netty应用到底是什么样子。
同样是以简化的Echo Server为例,下图是Netty官方提供的Server部分。
上面的例子,虽然代码很短,但已经足够体现出Netty的几个核心概念,请注意我用红框标记出的部分:
你可以参考下面的简化示意图,忽略Inbound/OutBound Handler的细节,理解这几个基本单元之间的操作流程和对应关系。
对比Java标准NIO的代码,Netty提供的相对高层次的封装,减少了对Selector等细节的操纵,而EventLoop、Pipeline等机制则简化了编程模型,开发者不用担心并发等问题,在一定程度上简化了应用代码的开发。最难能可贵的是,这一切并没有以可靠性、可扩展性为代价,反而将其大幅度提高。
针对Netty的一些实现原理,很可能成为面试中的考点,例如:
对于这些知识点,公开的深入解读已经有很多了,在学习时希望你不要一开始就被复杂的细节弄晕,可以结合实例,逐步、有针对性的进行学习。我的一个建议是,可以试着画出相应的示意图,非常有助于理解并能清晰阐述自己的看法。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。