从经典网络IO模型到新异步IO框架io_uring

网络IO两阶段

网络IO涉及用户空间和内核空间,一般会有以下两阶段:

  • 一阶段:等待数据准备就绪,即数据被copy到内核缓冲区(wait for data)

  • 二阶段:数据从内核缓冲区copy到用户缓冲区(copy data from kernel to user)

根据以上两阶段不同,出现了多种网络IO模型,接下来一一进行分析。注意所展示的图中(wait for data)和(copy data from kernel to user)字段分别表示一二阶段。

 

 

1.  阻塞IO(Blocking IO)

socket fd默认blocking,从下图可以看出,用户进程全程阻塞直到两阶段完成,即,一阶段等待数据会block,二阶段将数据从内核copy到用户空间也会block,只有copy完数据后内核返回,用户进程才会解除block状态,重新运行。

图片

 

结论:阻塞IO,两阶段都阻塞。

 

 

2.  非阻塞IO(Non-blocking IO)

可使用fcntl将socket设置为NON-BLOCKING,使其变为非阻塞。

  •  
 

fcntl(fd, F_SETFL, O_NONBLOCK);

如下图,用户进程recvfrom时,如果没有数据,则直接返回,因此一阶段不会阻塞用户进程。但是,用户进程需要不断轮询kernel数据是否准备好(会造成CPU空转,浪费资源)。当数据准备好时,用户进程会阻塞直到数据从内核空间copy到用户空间完成(二阶段),内核返回结果。

图片

其中recvfrom<

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值