百科问答小站 logo
百科问答小站 font logo



在同一个进程中,能否在一个线程用一个epoll大循环管理多个UdpServer+TcpServer? 第1页

  

user avatar   haozhi-yang-41 网友的相关建议: 
      

可以。

实践上,在某些特定场景下也会有实际价值:

例如说探活/心跳服务。这类服务需要同时应付极大量的客户,而且自身消耗的资源尽可能少(毕竟不是复杂的业务功能服务)。但具体每个请求都特别短,处理起来也特别简单。用这种模式可以极大减少无意义的并发切换开销,简化处理流程,同时也能提高稳定性和可靠性。

另外就是在这基础上还可以扩展一下:通常情况下这么维持心跳。极偶然会有些需要复杂处理的指令(例如说一些客户端的异常状态上报),就fork一个短进程出来单独处理。

总之,这类架构有种短小精致的“古典美”。作为学习用途比较多,不太符合当前主流的发展思路,实际大规模应用得比较少,但在某些特定场景还是能简单这样的遗存的。




  

相关话题

  抛开一切暂时不可能的因素,若是Linux系统收费或者停止开源,我们现状又会怎么样? 
  操作系统中到底是谁分配的资源? 
  为什么Markdown在2004年才出现,而推广更晚? 
  有哪些在线 Linux 环境可以 ssh 登录来玩? 
  因为折腾了linux导致业务水平跟不上怎么有什么较好的处理办法? 
  Linux内核代码大佬们如何观看的? 
  为什么说linux桌面不稳定、差呢? 
  Unix网络编程里的阻塞是在操作系统的内核态创建一个线程来死循环吗? 
  想买个域名然后搭建一个网站,需要哪些东西?,特别是主机服务器问题,请有经验的帮指点下,谢谢了 
  Windows 在服务端市场没人用吗? 

前一个讨论
python中用isdigit函数判断是否为数字,但当输入为负数是不行?怎么解决?
下一个讨论
大连幼师称望疫情不停被列失信人员,搞不懂,这和失信有啥关系呢?





© 2025-05-29 - tinynew.org. All Rights Reserved.
© 2025-05-29 - tinynew.org. 保留所有权利