HTTP是无状态、单向的协议,用户只能够通过客服端向服务器发送请求并由服务器处理发回一个响应。
一、AJAX长轮询(Long Polling via AJAX)
Comet 翻译为彗星,彗星长长的尾巴形容服务器和客户端需要建立一个“长”链接。基于这种架构开发的应用中,服务器端可以主动以异步的方式向客户端程序推送数据,而不需要客户端显式的发出请求。
Comet 架构非常适合事件驱动的 Web 应用,以及对交互性和实时性要求很强的应用,如股票交易行情分析、聊天室和 Web 版在线游戏等。
AJAX长轮询简单来说,需要服务器与客户端需要保持一条长时间的请求。
客户端给服务器发送了一个Ajax(异步JavaScript和XML)请求,然后等待服务器响应,只要一有事件发生,服务器端就会在挂起的请求中送回响应。如果第一次的请求返回数据后,第二次请求会立刻发出,这种技术就称为Ajax 长轮询。
- 优点: 减少轮询次数,低延迟,浏览器兼容性较好。
- 缺点: 服务器需要保持大量连接。
二、WebSockets协议
与HTTP不同,WebSockets是一种通过TCP工作的有状态通信协议。
通信最初是作为HTTP握手开始的,但如果两个通信方同意,则通过WebSockets通信。
WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输(全双工)。
优点:更强的实时性,由于协议是全双工的,所以服务器可以随时主动给客户端下发数据。相对于HTTP请求需要等待客户端发起请求服务端才能响应,延迟明显更少
缺点:即使Websockets服务端已经发现连接断开,仍然没有办法推送数据,只能被动等待客户端重新建立好连接才能推送,在此之前数据将可能会被采取丢弃的措施处理掉。
三、总结
在弱网情况下,TCP长连接会经常性的断开,使用以上两种方法均有弊端,短轮询是弱网情况下更好的选择。还是要根据不同的使用场景选择服务器推送技术。