网络编程(9): 是否要将侦听socket设置为非阻塞

文章讨论了在单线程单循环模型下,处理侦听socket的三种不同策略:阻塞侦听、阻塞侦听挂载到epoll以及非阻塞侦听。每种策略都有其优缺点,如阻塞侦听可能浪费线程资源,而非阻塞侦听能更高效处理多个连接但可能在无连接时阻塞。最后提出,是否设置为非阻塞取决于具体场景,特别是连接的长短特性。
摘要由CSDN通过智能技术生成

是否要将侦听socket设置为非阻塞?

情况一: one thread one loop, 阻塞侦听socket一个线程

  • 这种情况下, 其他客户端的连接分配到其他的网络线程中(一个线程一个epoll loop),客户端socket必须是非阻塞。
  • 主线程阻塞接收客户端的连接(只有一个while(true)循环,没有挂载到epoll上),并分配给其他的网络线程。
  • 缺点:
    • 单独给阻塞的侦听socket分配一个线程,并没有挂载到epoll上,浪费线程资源。

情况二:基于情况一,将阻塞的侦听fd挂载到epoll上

  • 当有客户端连接的时候,epoll_wait返回调用accept接收连接,这样accept就不会阻塞线程,提高了线程的使用率。
  • 缺点:
    • 每个epoll_wait的轮询只能接收一个客户端连接,一次有多个客户端连接的时候,也只会调用一次accept,存在效率问题,相当于一次epoll_wait一次连接。
    • 但是在侦听fd的读事件触发的时候,用一个while循环接收连接,但是如果没有新连接的时候,accept会阻塞while循环,从而阻塞整个epoll loop。

情况三:将侦听fd设置为非阻塞的,挂载到epoll上

  • 可以在侦听fd有事件发生的时候,就可以通过while循环来接收接连,如果没有新连接发生,就可以将通过错误码EWOULDBOLCK返回。
  • 优点:
    • 可以一个epoll_wait的时候,接收多个连接,并且可以自由设置一次最大可以接收的连接数量。

TIP:

  • 对于one thread one loop的模型,主线程非阻塞accept挂载到epoll上,对于长连接的情况,也是比较浪费线程资源,但是对于短链接,会非常适应。
  • 对于长连接的话,可以选择主线程的loop中的epoll也可以挂载客户端的fd。

结论:

不一定要将侦听fd设置为非阻塞,不用IO复用管理即可,单独一个线程accept循环阻塞等待客户端连接。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值