netty 趣事
所属分类 netty
浏览量 54
基础概念
BIO、NIO和AIO这三个概念分别对应三种通讯模型:阻塞、非阻塞、非阻塞异步
BIO:一个连接一个线程,客户端有连接请求时服务器端就需要启动一个线程进行处理,线程开销大。
NIO:一个请求一个线程,客户端发送的连接请求会注册到多路复用器上,多路复用器轮询到该连接有I/O请求时才启动一个线程进行处理;
AIO:一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理
通俗地概括一下就是:
1)BIO是面向流的,NIO是面向缓冲区的;
2)BIO的各种流是阻塞的,而NIO是非阻塞的;
3)BIO的Stream是单向的,而NIO的channel是双向的。
NIO的的显著特点:
事件驱动模型、单线程处理多任务、非阻塞I/O,I/O读写不再阻塞,而是返回0、
基于block的传输比基于流的传输更高效、更高级的IO函数zero-copy、
IO多路复用大大提高了Java网络应用的可伸缩性和实用性。
基于Reactor线程模型。
官网
https://netty.io/
What’s Netty
Netty是一个Java NIO技术的开源异步事件驱动的网络编程框架,用于快速开发可维护的高性能协议服务器和客户端。
通俗一点就是一个将Java NIO进行了大量封装,并大大降低Java NIO使用难度和上手门槛的超牛逼框架。
Why Netty
1)高并发:基于 NIO(Nonblocking IO,非阻塞IO)开发,对比于 BIO(Blocking I/O,阻塞IO),他的并发性能得到了很大提高;
2)传输快:传输依赖于零拷贝特性,尽量减少不必要的内存拷贝,实现了更高效率的传输;
3)封装好:封装了 NIO 操作的很多细节,提供了易于使用调用接口
Netty的优势:
1)使用简单:封装了 NIO 的很多细节,使用更简单;
2)功能强大:预置了多种编解码功能,支持多种主流协议;
3)扩展性强:可以通过 ChannelHandler 对通信框架进行灵活地扩展;
4)性能优异:通过与其他业界主流的 NIO 框架对比,Netty 的综合性能最优;
5)运行稳定:Netty 修复了已经发现的所有 NIO 的 bug,让开发人员可以专注于业务本身;
6)社区活跃:Netty 是活跃的开源项目,版本迭代周期短,bug 修复速度快
Netty高性能表现在哪些方面?
1)IO 线程模型:同步非阻塞,用最少的资源做更多的事;
2)内存零拷贝:尽量减少不必要的内存拷贝,实现了更高效率的传输;
3)内存池设计:申请的内存可以重用,主要指直接内存。内部实现是用一颗二叉查找树管理内存分配情况;
4)串形化处理读写:避免使用锁带来的性能开销;
5)高性能序列化协议:支持 protobuf 等高性能序列化协议
About Netty Author & Leader
Netty的创始人是韩国人Trustin Lee,80年出生,8岁起在MSX迷你计算机上编写BASIC程序,
爱好游戏编程以及使用汇编、C和C++解决编程问题,1998年获得韩国信息奥林匹克竞赛铜牌。
就读于韩国Yonsei大学计算机系期间,曾为多家公司编写高性能网络应用以及少量的web程序,
毕业后,就职于Arreo通讯公司,该公司为韩国最大的移动短信提供商之一。
他现在韩国line公司工作(据他个人博客显示,他以于2020年8月底从Line离职了 ),早前应用较多的Mina也是这牛人的作品
个人博客:https://t.motd.kr/
Github:https://github.com/trustin
Netty目前的项目leader是德国人Norman Maurer(之前在Redhat,全职开发Netty),也是《Netty in Action》的作者,目前是苹果公司高级工程师
个人博客:http://normanmaurer.me/
Github:https://github.com/normanmaurer
What can Netty do
物联网应用无处不在,大量的项目都牵涉到应用传感器和服务器端的数据通信,
Netty作为基础通信组件、能够轻松解决之前有较高门槛的通信系统开发,
不用再为如何解析各类简单、或复杂的通讯协议而烦恼
互联网系统讲究的都是高并发、分布式、微服务,各类消息满天飞(IM系统、消息推送系统就是其中的典型),
可以基于Netty来实现自己的HTTP服务器、FTP服务器、UDP服务器、RPC服务器、WebSocket服务器、Redis的Proxy服务器、MySQL的Proxy服务器等
上一篇
下一篇
WebSocket通信过程及原理
websocket 聊天室简单例子
netty http server 实例
Netty ChannelPipeline Inbound Outbound
netty 架构原理简介
grafana prometheus 查询结果为空处理