点名表扬最近收集的浏览器更新,記得半年前有對Chrome後台進行反饋過,說如果頁面與頁面之間有分類就好了,結果今天看到現成,讓我這個頁面殺手感到驚喜呀;相比之下一直沉迷於搜索引擎修補的百度也終於有點新意了,開始放下自我觀察用戶了,而這些小改變也許是大廠走向光明或者沒落的轉機,我得把它記下來先。

网页端的消息接收,用什么方式好呢?

电话簿
网页收发消息是一个常见的系统应用场景,通常我们有两种方式来完成消息的发送,一种是通过客户端来拉取消息,一种是服务端推送消息,到底使用哪种方式好一点呢?
具体使用哪种方式,我们需要根据实际的业务场景来分析,没有绝对正确的方式,只有适不适合。所以,我们分析一下网页端的用户一般都存在哪些应用场景:
系统将通知发送给用户——这种场景下,用户对于消息的实时性要求并不高
用户和用户之间发送聊天消息——这种场景下,用户就对实时性的要求很高了,越实时越好
我们抛开纯技术实现不谈,只是从解决方案来谈,由于是使用的是网页端,HTTP协议是通过“请求-响应”的方式传递,网页端和服务端之间是没有消息通道的,那么怎么来实现消息的接收呢?
轮询拉取
轮询拉取可以说是所有消息的实现方案中最简单的一种,实现起来也非常简单。

大致的实现方法如下:
发送方发送消息后,消息先进入队列中暂存(也可以是数据库)
网页端建立一个timer,固定时间(例如:30秒)轮询到队列(或数据库)中拉取消息
无论有没有拉到消息,收到返回的消息后,30秒后再次轮询拉取
这种方式最大的优势就是实现非常简单,而且容易理解,早期的聊天室基本都是这种实现方式,我曾经给朋友做过一个答题的系统,有多个终端,每个终端看到的内容需要有所不同,也是使用的这种实现方式。
当然这种实现方式的缺点也是非常明显:
时效性差:随着timer间隔时间的长短,收到消息的延时时间会被拉长,以30秒为例,消息最大的延时就会达到30秒
效率差:网页端会不停的请求服务器,但是发消息的频率事实上并没有这么高,如果10次轮询才拉到一条消息,那么有效性只有10%,大量的浪费了服务器资源
使用这种方式,时效性和效率是矛盾的,我降低timer的间隔时间,就可以提高时效性,但是会降低效率,例如:间隔时间降低到1秒,这种基本就可以趋近于实时了,但是可能300次轮询才会拉到1条消息,有效性只有0.3%了。
所以,由于这个不可调和的矛盾存在,这种解决方案只能适用于一些同时在线用户少,对实时性要求不高的场景中。
长连接
如果想要同时保证时效性和效率,其实长连接是一个不错的选择,一般我们的PC端聊天软件都是使用的长连接方式来实现。而网页端的长连接实现方式通常有两种:
WebSocket
FlashSocket
FlashSocket就不说了,如果不是网页游戏的话其实很少会用到这个方案来做长连接,它要求用户必须安装了Flash插件。如果是HTML网页端的话,其实更多会选择WebSocket这种方案,WebSocket的优点非常明显,建立一次握手以后,服务端和网页端就可以双向通信了,摆脱了HTTP的Request-Response的限制,消息的及时性和效率都大幅度的提升了。
但是WebSocket也不是那么简单,其中的坑也非常的多,如何单个生产者推送给多个消费者,如何保证不重复推送,断线以后的重连等等。当然更重要的是,不同的浏览器对于WebSocket的支持可能不同,兼容性也是一大问题,所以使用得并不是很多。
那有没有一种更常用的方法来处理消息的接收呢?
HTTP长轮询
想要建立一条HTTP长轮询的通道,我们需要在浏览器和服务器之间建立一条通知连接。

而这条通知连接不同于普通的HTTP连接,它要有一些特殊性:
这个HTTP连接只能用来收取推送的消息
不同于普通的Request-Response HTTP请求,这个HTTP连接不会马上响应,会先被Hold在这里,知道接到通知的消息或者超过了约定的时间(我们都知道,HTTP请求是会有超时的,一般我们都会设置一个请求超时的阈值,如果超过这个阈值,那么请求就会被粗暴的断开,返回一个错误消息,为了保证我们的请求不被粗暴的对待,我们需要在超时之前优雅的返回一个结果)
怎么来Hold住这个请求呢?
场景一:队列里面有消息

发起一个通知连接HTTP请求
发现消息队列里面有消息,于是拿到消息然后立刻返回
收到返回的消息后,立刻再次发起通知连接的请求
场景二:队列里面没有消息

发起一个通知连接HTTP请求
发现消息队列里面没有消息,于是一直等待直到达到时间阈值然后返回
收到返回的消息后,立刻再次发起通知连接的请求
个人认为,长轮询的请求就一直保持对消息队列的数据拉取就行,如果有实时的消息来了,也等到它进入消息队列以后再处理,这样可以防止消息丢失,也可以降低系统的复杂度。
总的来说,网页端的消息接收,用什么方式好呢?拉和推都可以,每种方式有每种方式的优缺点。
如果业务不复杂,实时性不高,建议轮询拉取
最佳方案是推,但是WebSocket和FlashSocket各有局限性,实现起来也麻烦一点
常见方式就是长轮询,需要开辟一条专用的消息通道。 https://t.cn/R2WxlNJ

#张店[超话]##淄博[超话]#生活話語

(来自瀏覽器)

人生是记忆的集合体,有品不尽的苦辣酸甜。生命看破了不过是无常;爱情看破了不过是聚散罢了,而在聚散离合之间,又充盈了多少悲欢交集的缘分。本以为萍水相逢,缘起缘灭在一瞬間。而这瞬間又有多少能修到了朝朝暮暮的缘分。 ​ https://t.cn/RJZZyNE


发布     👍 0 举报 写留言 🖊   
✋热门推荐
  • 那时还没喜欢看小说,因此错过了墨香,待她退圈了我才知原来还有这位才华横溢,富有浪漫色彩的作者,当时我第一眼就喜欢上她,可那又如何呢,她人已经闭关。3.25日我不
  • #情感语录[超话]##情感#【白清宁与萧瞳】(音乐舞剧) 歌曲顺序(这音乐舞剧是根据龙啸九天先生的佳作《落花记》部份内容改编的. )(希望大家喜欢, 并多给意
  • 只有一颗充满爱、散播爱的心,徜徉在天与地之间,平静、喜悦、通透,我与万物链接,我即是万物;我是风中一微尘、沧海之一粟,也是天地间的所有,是宇宙,是心……明天状态
  • 根据正弦函数,等效质量(EM)是加速跑过程中克服自身质量、维持前进所需的推力 g’与匀速跑动过程中垂直方向重力 g 之比。引入等效坡度(ES)是为将人体在地平面
  • 昨天上班的时候我人就跟没来全一样,浑浑噩噩的(不错了,我昨天还写了篇网评呢,在这种情况下,我也是真了),今天我才算是满血复活! #吸脂#啦哩哩哩哩~阿如糸的碎碎
  • 那么你的一个微笑,将照亮我的整个世界??熊先生说: 如果你只是为了说服别人而去写作,不仅真理会离你越来越远,连自己也会离你越来越远。”“我喜欢一个人,我想给她
  • 今天出去玩回来 室友说她们今天聊天说到感觉我是每天最快乐的 不追星(有个舍友追 也不用受爱情的苦(也有舍友正在 虽然我天天念叨着想谈恋爱 每天心情好就化个小妆
  • 逢君一程,我命之幸一路花开,步步为赢与君同行,朝朝辞暮成毅生日快乐[送花花][给你小心心]Part1 217份线下应援礼包发放成毅的果果都可领取先到先得超话等
  • #袁冰妍[超话]#yby#袁冰妍倾城亦清欢# yby#袁冰妍凤清欢# .浪漫主义者都是暗处迎盛阳的玫瑰. @袁冰妍 #袁冰妍[超话]#
  • 个人理解眼尾的走向是往下的,眼线和长睫毛(长得上下睫毛碰一起了)都有把眼尾下压的视觉效果,显得很纯情乖顺,特别伟大的眼部建模…漂亮的眼睛………石膏眼好多家都做得
  • 所以,如果你也想拥有Mike Faist这种随性而松弛的时尚感,不妨从简约的穿搭开始,再加上一些自然的发型和恰到好处的配饰,相信你也能成为那个随性而自信的时尚i
  • 9,思源电气,002028,现价70.53元10,申菱环境,301018,现价21.98元个人观点,仅做参考~下周谨慎关注10个活跃股1,新中港,605162,
  • 不,或许是我错了,你没打算深爱,你只是为了图一时好奇新鲜,时间久了就腻了,我一开始就错了,还以为是一个多么深爱我的人,后来才发现男性多是现实又薄情之。 【篇幅有
  • 第二节,诗人对落花进行了多重曝光,展示了其多方面的美感,又是掩住大地,又是吹送幽梦,又是倚着细雨落下,又是印在接吻的余香。第三节,诗人连着两个不要惊醒,是因为诗
  • #赤练[超话]##520超话许愿墙#赤练红莲#天行九歌红莲#秦时明月赤练#赤练#红莲#赤练214与卿初见# 花开乱世 越晚越美越招摇 落红是毒药 生手深宫
  • 天后Riri蕾哈娜自家品牌Fenty Beauty来上海啦,兴奋的心情已经藏不住了,这次是限时5天快闪店活动,我第一时间就来打卡。现场分为6个空间 趣味活动装
  • 随机雷转路 爱厕如命 可能为任何人冲锋陷阵雷ASTRO金明俊、朴真祐、车银优、文彬、尹产贺SMROOKIES文泰一、徐英浩、李泰容、中本悠太、钱锟、金道英、TE
  • 对于很多拥有欧米茄机械表的人来说,加薇 p ey mey (无空格)在他们的潜意识里:如果谈到适合男生的手表哪个品牌好?那么第一只就必须是欧米茄经典腕表蝶
  • 成毅|赴山海|萧秋水|李沉舟|肖明明|莲花楼|李莲花|李相夷|深潜|云弘深|卢云|@成毅#成毅赴山海#cy#成毅肖明明萧秋水李沉舟# 433❤❤️⸝ ᶫᵒᵛᵉ
  • 追剧日历磕演技佘诗曼、林峯、罗子溢如果有一天,我决定删了你,并不代表你对我不再重要,而是我怕我自己越陷越深,原来真的有那么一个人,我无数次的想要放弃,但终究还是