redis自学(16)select
Select
select是Linux中最早的I/O多路复用实现方案:
nfds是FD遍历的一个上限,遍历到这个值的时候,就意味着不用再往后去遍历了。
fds_bits 是存储1024个比特位,代表1024个fd,这个数量是__d_mask四个字节共32个比特位乘以fds_bits的32长度得到的
Select的执行流程:
根据fd的整数值,把对应的比特位赋值为1
传递进内核空间,遍历,有就绪的就后续操作,没有就绪的就休眠
有就绪的或者休眠唤醒有就绪数据,就根据队对应的fd修改,就绪的还是1,未就绪的就删除或者标记为0
然后把结果拷贝回用户空间,然而并不知道到底哪个fd就绪了,就要遍历找到就绪的fd。
Select模式存在的问题:
- 需要将整个fd_set从用户空间拷贝到内核空间,select结束还要再次拷贝回用户空间
- Select无法得知具体是哪个fd就绪,需要遍历整个fd_set
- fd_set监听的fd数量不能超过1024