Netty之nio三大组件
一、nio概念
non(new)- blocking io 非阻塞IO,是jdk1.4后新增的api,主要面向缓冲区的。
二、nio三大组件
1.Channel
channel是读写数据的双向通道。可以从channel将数据读入buffer,也可以将buffer的数据写入channel。
常见的Channel有
- FileChannel —— 文件处理时的数据传输通道
- DatagramChannel —— UDP网络编程时的数据传输通道
- SocketChannel —— TCP网络编程时的数据传输通道,用于服务器端
- ServerSocketChannel —— TCP网络编程时的数据传输通道,客户端和服务器端都可用
2.Buffer
buffer是内存缓冲区,暂存从channel中读写的数据
常见的Buffer有
- ByteBuffer —— 以字节为单位缓冲数据,抽象类
- MappedByteBuffer
- DirectBuffer
- HeapByteBuffer
- ShortBuffer*
- IntBuffer
- LongBuffer
- FloatBuffer
- DoubleBuffer
3.Selector
selector是多路复用器,它的作用就是配合一个线程不断轮询多个channel,获取这些channel上发生的事件,Selector可以监听的状态有:Connect(客户端连接成功后)、Accept(准备好进行连接)、Read(可读)、Write(可写),当监听到某一Channel的某个状态时,才允许对Channel进行相应的操作。
selector的select()会阻塞直到channel发生了读写就绪事件,然后select()方法会返回这些事件交给thread处理。fileChannel因为是阻塞式的,所以无法使用selector。
这些channel工作在非阻塞模式下,不会让线程吊死在一个channel上,适合连接数多但流量低的场景(low traffic)
总结
Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)。通道表示打开到 IO 设备(文件、套接字)的连接。若使用 NIO 系统,需要获取用于连接 IO 设备的通道以及用于容纳数据的缓冲区,然后操作缓冲区,对数据进行处理。
总体而言,通过Selector配合一个线程来管理多个通道,而通道负责传输,缓冲区负责存储。