netty学习记录
什么是netty?
- 是一个高性能 事件驱动、异步非堵塞的io开源框架;
- 基于NIO的客户端,服务器端编程框架;
- 稳定性和伸缩性;
(BIO(Blocking I/O)同步阻塞I/O、NIO (New I/O) 同步非阻塞I/O、AIO (Asynchronous I/O) 异步非阻塞I/O;)
其中nio1.0为同步非阻塞,nio2.0为aio;
netty使用场景
- 高性能领域
- 多线程并发领域
- 异步通信领域
BIO通信
- 一个线程负责连接
- 一请求一应答
- 缺乏弹性伸缩能力
伪异步IO通信
- 线程池负责连接
- M请求N应答
- 线程池阻塞
NIO通信
- 缓冲区Buffer:读写数据都放在缓冲区,通过缓冲区操作
- 通道Channel:双向通道,inputStream,outStream都是单向的,所以channel可以进行同时进行读和写
- 多路复用器Selector:循环Channel
AIO通信
- 连接注册读写事件和回调函数
- 读写方法异步
- 主动通知程序
什么是WebSocket?
- H5协议规范
- 握手机制
- 解决客户端与服务端时事通行而产生的技术(基于TCP协议)
WebSocket的优点
- 节省通信开销
- 服务器主动传送数据给客户端
- 实时通信
WebSocket建立连接
- 客户端发起握手请求
- 服务端响应请求
- 连接建立
WebSocket生命周期
- 打开事件
- 消息事件
- 错误事件
- 关闭事件
WebSocket关闭连接
- 服务器关闭底层TCP连接
- 客户端发起TCP Close