gpt4 book ai didi

iphone - 如何从服务器(而非 Web 服务器)最好地为 >10,000 个 iPhone 客户端提供服务

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:01:27 25 4
gpt4 key购买 nike

我正在尝试构建一个服务器来处理许多与 iPhone 客户端的并发连接,而​​无需多线程。我将大约每 10-30 秒向所有客户端发送一次消息,但大多数消息将相同或非常相似且易于分类。鉴于高并发但对数据排序需求低的设置,我正在尝试为我的服务器设置找到最佳解决方案。

我一直在看事件驱动的包,比如 EventMachine、Twisted、node.js 等。看来 Twisted 和 EventMachine 基本上是一个折腾,node 可能更快,但还没有完全准备好进行全面开发.这引出了几个问题:

  1. Node 不适合关键开发仅仅是因为它缺少 API 并且没有完全淘汰吗?或者可能存在使我的开发陷入困境的错误?

  2. 我正在考虑用 C 语言编写代码,因为磁盘 I/O 非常少,而且大部分应该很容易缓存。如果是这样,看来我应该使用非阻塞 UDP 套接字并自己处理 ACKing。我看过 poll()、select()、epoll(),但很难确定哪个是最好的以及如何调用它们。有什么想法吗?

  3. 如果我使用 Twisted 或 EventMachine(除了语言之外还有其他区别吗?我还不知道,所以我是一个空白),我应该尝试 TCP 还是 UDP?这些语言能否在不到一秒的时间内向 10,000 个客户端发送 1kB 数据?

如果有任何见解/建议,我将不胜感激,现在我正疯狂地围绕着太多的文档和博客转来转去,并且没有编程背景来整理它们(至少在保持理智的情况下)。

谢谢!迈克

最佳答案

我建议您在 Mac OS X snow leopard 上使用 C 语言开发服务器,使用 kqueue() 和 kevent() 或 kevent64() 来多路复用传入的客户端连接。

查看 IRC 服务器的免费源代码。这些服务器同时处理超过 10K 个客户端。

开始阅读 this page .尽管它有点过时,但它仍然是一个很好的入门引用。

关于iphone - 如何从服务器(而非 Web 服务器)最好地为 >10,000 个 iPhone 客户端提供服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3260386/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com