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
posted @ 2018-06-27 10:41  十黎九夏  阅读(103)  评论(0编辑  收藏  举报