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



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

  

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

可以。

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

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

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

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




  

相关话题

  Windows 的 PowerShell 和 Linux 的 terminal 有啥区别? 
  需要用到 Linux/Unix,是买 MacBook Pro还是 Windows 装Linux vm? 
  服务器是云主机好还是VPS主机好呢? 
  linux的TCP连接数量最大不能超过65535个,那服务器是如何应对百万千万的并发的? 
  linux 操作系统和 windows 操作系统哪个对科研更有效,有前辈能详细讲讲吗? 
  打算用 Linux 作为日常使用的操作系统,不做开发,哪个版本比较合适? 
  semaphore和mutex的区别? 
  哪些命令行工具让你相见恨晚? 
  Linux 发行版中哪个包管理器更强? 
  Linux 内核中,多线程栈空间模型是怎样的? 

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





© 2025-02-21 - tinynew.org. All Rights Reserved.
© 2025-02-21 - tinynew.org. 保留所有权利