我正在向 CppCMS 添加对服务器端事件的支持。我了解在通信级别上做什么的技术部分:客户端发送长轮询 XmlHTTPRequest,并等待响应,服务器接受连接并且在服务器端事件发生并将响应发送给客户端之前不响应。客户重复该过程。
但是,对于大多数 Web 开发人员来说,这太“低”了。有很多问题:我如何管理事件,我如何管理连接等等。
我想到了两种可能的模型:
定义了一些命名事件和服务器端,例如“134 号聊天室中的新消息”;当请求接受时,服务器端应用程序检查房间中的消息(例如在 DB 中),如果客户端没有新消息,它订阅事件并等待它。
当其他一些客户端向服务器发布数据时,它会通知所有应用程序“134 号聊天室中的新消息”事件,它们会唤醒并将这些消息发送给客户端,依此类推。
这个模型看起来仍然是相当“低级”的模型,但是它隐藏了所有的通知方法。
另一种选择是定义一些命名队列,以便每个客户端在连接到服务器时创建这样的队列并等待新消息。当某个客户端向“134 号聊天室”发布一条新消息时,在服务器端将其广播到连接到该“134 号聊天室”的所有队列,并将该消息传递给客户端。
然而,有许多问题被提出:
- 如何在单页级别管理队列和会话级别?
- 如何删除队列并在其上创建超时?
- 如果多个“窗口”订阅同一个队列会发生什么?
在服务器端创建一个持久对象,将服务器端事件和用户端事件粘合起来。它可以通过重定向到它的不同 XHR 请求进行通信。
因此客户端 (JavaScript) 注册事件并使用 XHR 和服务器端调度的事件通知等待它们,直到页面被重建。
那么,我想知道,服务器端推送技术背后最流行和推荐的 API 模型是什么?
谢谢
编辑:添加了第三个选项