高并发服务器中的多线程多进程缺陷问题:
多进程:
- 进程数量有限
- 代价太高(销毁,上下文切换)
- 受限于CPU
- 内存隔离
- 进程间通信代价高
以上都是不可避免的的
多线程:
-
受限于CPU
那么影响的是响应能力(例如1000个线程都在发收)全部调度,响应能力肯定受影响
-
阻塞
那么会有同学说改为非阻塞不就行了吗?
那么改为非阻塞不能完成收发信息就会结束,那么循环检测(eagain)虽然可以,但是无法感知IO,需要更多的CPU时间,效率明显不高。
以上都是不可避免的,所以引出了IO多路复用(IO多路转接)【select,poll,epoll】
作用:
感知IO(可读可写是否出错)是否就绪