游戏服务器是否为每个用户请求创建线程(如 dota 2)?

Does a game server create threads for each user request (like dota 2)?

对于 100,000 的用户群和每个游戏会话 4 个用户,我们是否应该为每个请求创建新线程,例如 create_session、move_player、use_attack 等?

我想知道处理大连接的最佳方式是什么,因为如果我们创建大量线程,上下文切换会占用大部分周期,如果没有创建线程,每个请求都必须等待上一个请求完成。

如果您的目标是可伸缩性,我会避免每个连接线程。最好有事件队列和线程池。

游戏公司可能会使用 UDP 等非基于连接的互联网协议。理论上所有请求都可以进入同一个套接字,因此您只需要 1 个线程来处理它。该线程可以将工作分配给其他线程。

您可以拥有一个更大的线程池,其中可以为任何线程分配任何作业。或者您可以进一步将工作组织成特定的作业,每个作业都有一个线程池来处理任务队列。但我不会为每个请求启动一个新线程。

您如何设计线程池和任务分配系统取决于您使用的任何语言的库和应用程序要求。