gpt4 book ai didi

php - 客户端从服务器检索聊天消息的最佳方式?

转载 作者:可可西里 更新时间:2023-11-01 01:03:54 26 4
gpt4 key购买 nike

我正在使用 JavaScript、jQuery、MySQL 和 PHP 构建一个聊天应用程序,我只是想知道客户端从服务器检索聊天消息的最佳方式是什么?我目前的潜在候选人是轮询、长轮询、HTML5 服务器发送事件 (EventSource) 和 WebSockets。其中哪一个是最快的(即时消息)和最有效的方法(如果可能也解释为什么)?或者如果有更好的方法,请在答案中详细说明。

此外,我还查看了 Node.js + Socket.IO,但我为它们找到的文档和示例代码对我来说毫无意义。

最后,我使用 XAMPP 作为我的本地服务器,使用 MySQL 作为这个应用程序的数据库。

如有任何帮助,我们将不胜感激。

最佳答案

巧合的是,您列出的选项是按照效率从低到高的顺序列出的。

轮询是效率最低的。它将轮询是否有消息,并在其他客户端发送和接收消息之间引入延迟。

长轮询更好;然后您可以在发送消息时收到消息,但重新连接时可能会稍有延迟。在此延迟期间,不会传递消息,但除此之外,它实际上是即时的。

COMET(未提及)比长轮询好,但比 Server-Sent Events 差。由于大多数 Web 服务器和浏览器的连接超时,它也必须偶尔重新连接,但无论何时发送消息都不需要重新建立连接。与长轮询一样,重新连接时可能会有延迟,但除此之外,通常是瞬时的。

Server-Sent Events 与 COMET 类似,但是当没有填充时,它有来自浏览器的 native 支持,因此它可以绕过超时限制并且只需要在其生命周期内建立一个连接(只要连接不存在) t坏了)。另一个优点是,如果连接断开,它会自动重新连接,而无需您编写任何客户端代码。这是瞬时的。

WebSockets 是迄今为止所有这些选项中最好的;它只需要一个连接,而且是双工的:您不仅可以通过它接收消息,还可以通过它发送消息,而不是每次要发送消息时都需要单独连接到服务器。与 Server-Sent Events 不同,它确实需要更多代码:如果连接断开,它不会自动重新连接,而且服务器端实现通常更复杂。我也不确定您是否可以将它与 Apache/XAMPP 一起使用。这是瞬时的。

Socket.io 是一个支持(几乎?)所有这些以及更多(例如,Flash 套接字)的库,并将其抽象为一个漂亮的 API,因此您不必处理浏览器支持的特性他们每个人。它和它选择使用的传输一样快,这取决于它运行的浏览器。它还可以减少您必须编写的代码量。但是,如果它对您来说太复杂并且您不关心旧版浏览器,那当然没有必要。此外,它真的很喜欢自己运行。您也许可以让 XAMPP 代理它,但同样,我不知道 Apache 是否可以配置为将 WebSocket 转发给它。

关于php - 客户端从服务器检索聊天消息的最佳方式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15869300/

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