netty(一)
五种网络IO模型
对于一个应用程序即一个操作系统进程来说,它既有内核空间(与其他进程共享),也有用户空间(进程私有),它们都是处于虚拟地址空间中。用户进程是无法访问内核空间的,它只能访问用户空间,通过用户空间去内核空间复制数据,然后进行处理
- 阻塞IO(同步)
- 非阻塞IO(同步IO)
- IO复用(同步IO)I/O是指网络I/O,多路指多个TCP连接(即socket或者channel),复用指复用一个或几个线程。意思说一个或一组线程处理多个连接。比如课堂上学生做完了作业就举手,老师就下去检查作业。(对一个IO端口,两次调用,两次返回,比阻塞IO并没有什么优越性;关键是能实现同时对多个IO端口进行监听,可以同时对多个读/写操作的IO函数进行轮询检测,直到有数据可读或可写时,才真正调用IO操作函数
- 信号驱动IO(同步IO)事先发出一个请求,当有数据后会返回一个标识回调,这时你可以去请求数据。好比银行排号,当叫到你的时候,你就可以去处理业务了(复制数据时阻塞)
- 异步IO
Netty的核心组件
-
channel
-
回调
-
Future
-
事件 和ChannelHandler
EventLoop EventLoopGroup channel 和 thread 四者之间的关系
- 一个EventLoopGroup 包含一个或者多个EventLoop
- 一个EventLoop 生命周期只和一个Thread绑定
- Channel 生命周期只注册一个EventLoop
- ChannelHandler 安装到channelPipeline的过程
- ChannelInitializer 的实现被注册到ServerBootstrap中
- 当ChannelInitializer .initChannel() 被调用时,Initializer 将pipeline中安装一组自定义的ChannelHandler
- ChannelInitializer 从pipeline中移除
Handler模型