IO多路复用的引出(为什么要用IO多路复用)

高并发服务器中的多线程多进程缺陷问题:

多进程:

  1. 进程数量有限
  2. 代价太高(销毁,上下文切换)
  3. 受限于CPU
  4. 内存隔离
  5. 进程间通信代价高

以上都是不可避免的的

多线程:

  1. 受限于CPU

    那么影响的是响应能力(例如1000个线程都在发收)全部调度,响应能力肯定受影响

  2. 阻塞

    那么会有同学说改为非阻塞不就行了吗?

    那么改为非阻塞不能完成收发信息就会结束,那么循环检测(eagain)虽然可以,但是无法感知IO,需要更多的CPU时间,效率明显不高。

以上都是不可避免的,所以引出了IO多路复用(IO多路转接)【select,poll,epoll】

作用:

感知IO(可读可写是否出错)是否就绪

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值