他们是NIO中实现多路复用的三种实现机制,是由Linux操作系统提供的。
用户空间和内核空间:操作系统为了保护系统安全,将内核划分为两个部分,一个是用户空间,一个是内核空间。用户空间不能直接访问底层的硬件设备,必须通过内核空间。
文件描述符 File Descriptor(FD) : 是一个抽象的概念,形式上是一个整数。实际上是一个索引值。指向内核中为每一个进程维护进程所打开的文件的记录表。当程序打开一个文件或者创建一个文件时,内核就会返回一个FD。Unix,Linux
sekect 机制:会维护一个FD的结合fd_set。将fd_set从用户空间复制到内核空间,激活socket。 x64 2048 fd_set是一个数组结构
poll 机制:和select机制是差不多的,把fd_set结构进行了优化,FD集合的大小就突破了操作系统的限制。pollfd结构来代替fd_set,通过链表实现。
EPoll:Event Poll.Epoll不在扫描所有的FD,只将用户关心的FD的事件存放到内核的事件表当中。这样,可以减少用户空间与内核空间之前需要拷贝的数据。
总结: | 操作方式 | 底层实现 | 最大连接数 | io效率 | 发布年 |
---|---|---|---|---|---|
select | 遍历 | 数组 | 受限于内核 | 一般 | 1984 |
pol | 遍历 | 链表 | 无上限 | 一般高 | 1997 |
epoll | 事件回调 | 红黑树 | 无上限 | 高 | 2022 |
java的NIO 在windows下 WindowsSelectorProvider,Linux下,根据linux的内核版本,2.6版本以上,就是EPollSelectProvider,否则就是默认的PollSelectProvider,