欢迎访问“郑州新闻网”,在这里您可以浏览到郑州发生的大小事,我们致力于为网民提供郑州新闻、健康,娱乐 、女性、房产、影视、图片,汽车等生活信息传播服务。

主页 > 郑州新闻 > 阿里云账号注册,阿里云代理商代购

阿里云账号注册,阿里云代理商代购

来源:郑州新闻网作者:锦体更新时间:2023-09-05 17:55:08阅读:

本篇文章947字,读完约2分钟

阿里云国际站经销商,主营阿里云,腾讯云,华为云,亚马逊aws,谷歌云gcp,微软云az,免费开户,代充值优惠大,联系客服飞机@jkkddd


长轮询

本文介绍消息服务MNS中使用LongPolling的最佳实践。
背景信息
消息服务MNS提供了LongPolling类型的接收消息的方法,在接收消息的时候把等待时间设置在1s~30s。使用LongPolling可以让请求一直在服务器上运行,等到有消息的时候才返回。既可以保证第一时间收到消息,又避免您发送大量无效请求。LongPolling是消息服务MNS的推荐用法。
LongPolling参数设置,请参见ReceiveMessage。
LongPolling需要HTTP层的长连接保持在服务器上,而对于服务器来说,HTTP层的长连接的资源是有限的。为了避免受到恶意攻击,消息服务MNS对单用户的每个Queue的连接数是有限制的。具体信息,请参见使用限制。
问题描述
您在单台机器上开启上百个线程,即发送上百个LongPolling的请求,同时访问消息服务MNS服务器获取消息。如果您使用了多台机器,那么可能同时发送上千个LongPolling的请求。
此时队列中没有消息,如果您再次发起LongPolling,消息服务MNS服务器就会返回:消息不存在。
因此,如果您是在一个While循环里不停的做LongPolling请求,而没有做异常处理,会导致您发送了大量的请求,不能达到使用LongPolling的预期效果。
解决方案
当您打开上百个线程同时访问消息服务MNS服务器时,如果队列里已经没有消息,就不需要上百个线程同时运行LongPolling。此时只需要打开1~N个线程运行LongPolling。当运行LongPolling的线程发现队列里有消息时,唤醒其他线程一起接收消息,达到快速响应的目的。
长轮询示例代码是一个使用MessageReceiver获取消息的最佳实践。所有获取消息的线程都新建了MessageReceiver,使用receiver.receiveMessage来获取消息。
MessageReceiver内部做了LongPolling的排他机制,只要有一个线程在做LongPolling,其它线程就需要等待。

标题:阿里云账号注册,阿里云代理商代购

地址:http://www.jtylhs.cn/zzxw/39640.html

免责声明:郑州新闻网是全球互联网中文新闻资讯最重要的原创内容供应商之一,本站部分内容来自于网络,不为其真实性负责,只为传播网络信息为目的,非商业用途,如有异议请及时联系btr2031@163.com,郑州新闻网的作者将予以删除。

郑州新闻网介绍

郑州新闻网立足郑州,纵览世界,依托郑州资讯优势,通过互联网提供最新、最快、最鲜活新闻资讯。为促进郑州市两个文明建设和社会信息化服务,为郑州扩大开放、走向世界服务。利用网络手段综合性、多角度、全方位地介绍郑州社会经济发展的最新的新闻、信息,引导郑州新闻的舆论导向,能过多种形式的互联网发布为用户提供更有价值的多方位资讯传播服务。