linux i/o multiplexing

Posted autoria

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux i/o multiplexing相关的知识,希望对你有一定的参考价值。

socket也是io的一种,阻塞的socket操作包括:

  • 输入:recv(), recvfrom(),缓冲区为空时阻塞
  • 输出:send(), sendto(),缓冲区为空时阻塞
  • 接受:accept(),无连接时阻塞
  • 连接:connect(),无响应时阻塞,对TCP连接而言会阻塞一个服务器往返时间

解决方案比较:

  select poll epoll
操作方法 遍历 遍历 回调
底层实现 数组 链表 哈希表
效率 O(n) O(n) O(1)
最大连接数 1024(x86), 2048(x64) 无限制 无限制
fd拷贝 每次调用都需要将fd集合从用户态拷贝到内核态 每次调用都需要将fd集合从用户态拷贝到内核态 调用epoll_ctl时拷贝进内存,之后每次epoll_wait不再拷贝

 

 

 

    

以上是关于linux i/o multiplexing的主要内容,如果未能解决你的问题,请参考以下文章

Linux性能优化实战:Linux 磁盘I/O是怎么工作的(上)(24)

Linux——标准I/O以及管道

Linux网络I/O模型简介

Java基础:I/O多路复用模型及Linux中的应用

Linux系统学习笔记:文件I/O

深入理解Linux I/O系统