虽然说用三个timer让选择集强行闪起来了,可是想知道知乎上,一个timer是怎么做到的,或者还有没有更简单的方法
[裂开]栅格数据的风格设置也很令人头秃
[二哈]动态热力图想都来不及想
[失望]我在网上找到一个很符合我想法的数据,可是人家大佬值更新到7月,虽然他把代码发了出来,可是Python和网页我一点都不懂
[允悲]虽然还有很多可以改的,但是实验报告交都交了
做了两天下午和晚上遭不住了,电脑前呆了就有一种困但是睡不着的感觉

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

电话簿
网页收发消息是一个常见的系统应用场景,通常我们有两种方式来完成消息的发送,一种是通过客户端来拉取消息,一种是服务端推送消息,到底使用哪种方式好一点呢?
具体使用哪种方式,我们需要根据实际的业务场景来分析,没有绝对正确的方式,只有适不适合。所以,我们分析一下网页端的用户一般都存在哪些应用场景:
系统将通知发送给用户——这种场景下,用户对于消息的实时性要求并不高
用户和用户之间发送聊天消息——这种场景下,用户就对实时性的要求很高了,越实时越好
我们抛开纯技术实现不谈,只是从解决方案来谈,由于是使用的是网页端,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

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

电话簿
网页收发消息是一个常见的系统应用场景,通常我们有两种方式来完成消息的发送,一种是通过客户端来拉取消息,一种是服务端推送消息,到底使用哪种方式好一点呢?
具体使用哪种方式,我们需要根据实际的业务场景来分析,没有绝对正确的方式,只有适不适合。所以,我们分析一下网页端的用户一般都存在哪些应用场景:
系统将通知发送给用户——这种场景下,用户对于消息的实时性要求并不高
用户和用户之间发送聊天消息——这种场景下,用户就对实时性的要求很高了,越实时越好
我们抛开纯技术实现不谈,只是从解决方案来谈,由于是使用的是网页端,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


发布     👍 0 举报 写留言 🖊   
✋热门推荐
  • 倒霉的第n天,幸运的第一天这两天真的是太倒霉了[泪],昨天宿管阿姨来检查卫生,结果我忘记了我的小锅放在了阳台,直接被端走了[悲伤],本来想求求情啥的,结果宿管阿
  • できましたかわいげたあスタイルです✌✌夏真っ盛りお洋服達も楽しんでいきたいですね〜‼---かわいげたあ❤️‍まさかワンピースの上にスカートを重ねていたとはおしゃ
  • [每一个繁花似锦,都是经历了暗涛汹涌;你没必要去努力改变一个人,正如你无法改变明日天气,你所要做的,只是持心自守,兵来将挡,水来土掩。[每一个繁花似锦,都是经历
  • 另外,我可能要走上二次正畸之路[悲伤]太难了抗AGES的第一步,就是预防血糖过高❗虽然不需要把所有的糖都戒掉,但不要长期选择偏甜的食物。反酸、烧心、胃胀,牢记这
  • 一个男生有多爱你 不是看他说了多少句我爱你而是在你负面情绪爆发甚至跟他吵架时 他会怎样对待你是啊 用嘴巴说爱你很容易 但是用行动来爱你却很难爱上那个乐观开朗的你
  • 如果阿里离开埃弗顿,最伤心的恐怕是热刺了。旋哥儿,今个儿四周年了,我想说“四周年快乐”[心][心][心]@秦霄贤土耳其贝西克塔斯正在努力求购阿里,无论是租借还是
  • 詮論:謂於一切生滅之法相中,覺了通達諸法實相;本自不生不滅,安隠忍可於心而不動;至心實相,不起分别,故可承办所應办之事,即菩提之大願也。觀世音菩薩老人家,祂是用
  • 于无声处,拾一颗纯朴的心,做一个善良的人,该有多美。于无声处,拾一颗纯朴的心,做一个善良的人,该有多美。
  • 3. 要是你问我,我要是把我的所有资金都投入到一家公司,二十年不动,我会选宝洁还是可口可乐,其实宝洁的产品线更多元化,但是比较起来,我认为可口可乐的确定性比宝洁
  • ---持币者避高就低,利用局部的活跃,关注轮动休整后、未完全走弱的板块,或者短期回调后、未破位的个股(20日均线未破)。个股:(中线持股不变)短线:(持股不变)
  • 总价20万买佛山市中心+2号线地铁口,有个人红本不动产权证房子首付低至2万,十年月供2000,包租保底1800/月,以租抵供0压力禅城季华路中央商务大道旁,地铁
  • 【带话题#我的小小灵感天地# 卷[鲜花]+关@明基专业设计显示器 ,在评论区晒晒你的灵感空间】8月31日抽取3位小伙伴送出100元京东E卡,此外笨球还会选取评论
  • #秦霄贤[超话]#今年的8.17如约而至 每一年的初秋都是我们梦的开始​四周年快乐呀秦先生​你的行程越来越满知名度越来越高四周年了我真的好高兴啊只是这一路所经历
  • 完善利益联结,实现发展共享,除收取土地租金外,对于愿意用土地、闲置房屋、林盘等资源入股、联营的村民,资源经评估后在村集体经济合作社、村资产管理公司中参与盈利分配
  • 首先是,这一季主要在铺开世界观,因此主题不够明确,主角和反派的动机都不强烈,观感上就好像为了让主角有成长的时间,反派那边也松松散散,挨个上场,游戏人间。Owen
  • 英1-幸福之路 D1读书的意义在于寻找到自己轨道或者是搭建轨道,长时间内心的匮乏会出现脱轨或是偏轨,便无法得到加速,而在一条正确的轨道上前行,就会走的非常快;影
  • 山东巨匠机械集团XYD-200履带水井钻机一、XYD-200履带式水井钻机优点1、钻机采用自动伸缩式钻塔,用两支油缸作支撑,一组液压阀控制钻塔仰卧,操作省时省力
  • 5.深夜食堂老谢野馄饨如果说青岛是山东省最大的“夜市”那么野馄饨一定是其中的代表。5.深夜食堂老谢野馄饨如果说青岛是山东省最大的“夜市”那么野馄饨一定是其中的代
  • 就拿生活中不可能没有执念来说,有两种情况,对生活有积极的改变,正确的推动,或者说美好的突破的这种执念,这叫生活的正面作用。就拿生活中不可能没有执念来说,有两种情
  • 我就喜欢这个改编我就喜欢这个舞台舞美,如果你非要说按照原来的唱那还叫什么改编,不然你报警吧这三天属实有点玩累了[衰]周日 和wpq打卡蹦床馆+兰正韩+麦当劳口味