网页收发消息是一个常见的系统应用场景,通常我们有两种方式来完成消息的发送,一种是通过客户端来拉取消息,一种是服务端推送消息,到底使用哪种方式好一点呢?
具体使用哪种方式,我们需要根据实际的业务场景来分析,没有绝对正确的方式,只有适不适合 。所以,我们分析一下网页端的用户一般都存在哪些应用场景:
- 系统将通知发送给用户——这种场景下,用户对于消息的实时性要求并不高
- 用户和用户之间发送聊天消息——这种场景下,用户就对实时性的要求很高了,越实时越好
轮询拉取轮询拉取可以说是所有消息的实现方案中最简单的一种,实现起来也非常简单 。
文章插图
大致的实现方法如下:
- 发送方发送消息后,消息先进入队列中暂存(也可以是数据库)
- 网页端建立一个timer,固定时间(例如:30秒)轮询到队列(或数据库)中拉取消息
- 无论有没有拉到消息,收到返回的消息后,30秒后再次轮询拉取
当然这种实现方式的缺点也是非常明显:
- 时效性差:随着timer间隔时间的长短,收到消息的延时时间会被拉长,以30秒为例,消息最大的延时就会达到30秒
- 效率差:网页端会不停的请求服务器,但是发消息的频率事实上并没有这么高,如果10次轮询才拉到一条消息,那么有效性只有10%,大量的浪费了服务器资源
所以,由于这个不可调和的矛盾存在,这种解决方案只能适用于一些同时在线用户少,对实时性要求不高的场景中 。
长连接如果想要同时保证时效性和效率,其实长连接是一个不错的选择,一般我们的PC端聊天软件都是使用的长连接方式来实现 。而网页端的长连接实现方式通常有两种:
- WebSocket
- FlashSocket
但是WebSocket也不是那么简单,其中的坑也非常的多,如何单个生产者推送给多个消费者,如何保证不重复推送,断线以后的重连等等 。当然更重要的是,不同的浏览器对于WebSocket的支持可能不同,兼容性也是一大问题,所以使用得并不是很多 。
那有没有一种更常用的方法来处理消息的接收呢?
HTTP长轮询【网页端的消息接收,用什么方式好呢?】想要建立一条HTTP长轮询的通道,我们需要在浏览器和服务器之间建立一条通知连接 。
文章插图
而这条通知连接不同于普通的HTTP连接,它要有一些特殊性:
- 这个HTTP连接只能用来收取推送的消息
- 不同于普通的Request-Response HTTP请求,这个HTTP连接不会马上响应,会先被Hold在这里,知道接到通知的消息或者超过了约定的时间(我们都知道,HTTP请求是会有超时的,一般我们都会设置一个请求超时的阈值,如果超过这个阈值,那么请求就会被粗暴的断开,返回一个错误消息,为了保证我们的请求不被粗暴的对待,我们需要在超时之前优雅的返回一个结果)
推荐阅读
- 曹丕的主要成就 曹丕作为一位政治家,有何成就?
- 八国联军侵华百姓搭梯子 八国联军什么时候入侵的紫禁城
- 日军对台儿庄战役的评价 台儿庄战役的战果和意义
- 宝宝益生菌什么作用
- 芒果紅茶的做法,绿茶蜜枣芒果冰皮月饼的做法
- 秋水仙碱一天吃几次才算是正常的
- 白茶与茶欣赏,制作不同的茶
- 白花茶的功效与作用,桃花的功效和作用
- 洛神罗汉果茶的做法,罗汉果茶的做法
- 小儿健脾丸的成份和注意事项