java面试题网

普通会员

160

帖子

12

回复

165

积分

楼主
发表于 2018-06-01 17:37:44 | 查看: 5248| 回复: 1

Netty的高性能表现在哪些方面

从大的方面看,netty性能高效主要体现在:

1.io线程模型

使用reactor模式,同步非阻塞。这决定了可以用最少的资源做更多的事。

2.内存零拷贝

使用直接缓存(Zero-copy, 在操作数据时, 不需要将数据 buffer 从一个内存区域拷贝到另一个内存区域. 因为少了一次内存的拷贝, 因此 CPU 的效率就得到的提升.)

3.内存池设计

申请的内存可以重用,主要指直接内存。

内部实现是用一颗二叉查找树管理内存分配情况。

4.串形化处理socket读写,避免锁,即一个指定socket的消息是串形化处理的。这样性能比多个线程同时 处理一个socket对应消息要好,因为多线程处理会有锁。

5.提供对protobuf等高性能序列化协议支持



文章来自www.wityx.com,转载请注明出处!原文地址http://www.wityx.com/post/483_1_1.html


java面试题交流群:327440556

普通会员

115

帖子

83

回复

167

积分
沙发
发表于 2019-09-23 15:41:26

为什么选择Netty?
Netty 是业界最流行的 NIO 框架之一,它的健壮性、功能、性能、可定制性和可扩展性在同类框架中都是首屈一指的,它已经得到成百上千的商用项目验证,例如 Hadoop 的 RPC 框架 Avro 使用 Netty 作为通信框架。很多其它业界主流的 RPC 和分布式服务框架,也使用 Netty 来构建高性能的异步通信能力。
Netty 的优点:
API 使用简单,开发门槛低;
功能强大,预置了多种编解码功能,支持多种主流协议;
定制能力强,可以通过 ChannelHandler 对通信框架进行灵活的扩展;
性能高,通过与其它业界主流的 NIO 框架对比,Netty 的综合性能最优;
社区活跃,版本迭代周期短,发现的 BUG 可以被及时修复,同时,更多的新功能会被加入;
经历了大规模的商业应用考验,质量得到验证。在互联网、大数据、网络游戏、企业应用、电信软件等众多行业得到成功商用,证明了它完全满足不同行业的商用标准。
正是因为这些优点,Netty 逐渐成为 Java NIO 编程的首选框架。

您需要登录后才可以回帖 登录 | 立即注册

java面试题网www.wuliaokankan.cnjava建站系统提供技术支持V2.1 网站地图 © 2016-2018