当前位置:首页 > 搭建教程 > 正文内容

消息队列对即时通讯软件场景的重要性!

im源码2年前 (2024-01-07)搭建教程761

即时通讯必用的消息队列

一、消息队列(MQ)概述



消息队列(Message Queue),是分布式系统中重要的组件,其通用的使用场景可以简单地描述为:




当不需要立即获得结果,但是并发量又需要进行控制的时候,差不多就是需要使用消息队列的时候。


消息队列主要解决了应用耦合、异步处理、流量削锋等问题。




当前使用较多的消息队列有RabbitMQ、RocketMQ、ActiveMQ、Kafka、ZeroMQ、MetaMq等,而部分数据库如Redis、Mysql以及phxsql也可实现消息队列的功能。




二、消息队列使用场景



消息队列在实际应用中包括如下四个场景:




应用耦合:多应用间通过消息队列对同一消息进行处理,避免调用接口失败导致整个过程失败;


异步处理:多应用对消息队列中同一消息进行处理,应用间并发处理消息,相比串行处理,减少处理时间;


限流削峰:广泛应用于秒杀或抢购活动中,避免流量过大导致应用系统挂掉的情况;


消息驱动的系统:系统分为消息队列、消息生产者、消息消费者,生产者负责产生消息,消费者(可能有多个)负责对消息进行处理;




下面详细介绍上述四个场景以及消息队列如何在上述四个场景中使用:




2.1 异步处理



具体场景:用户为了使用某个应用,进行注册,系统需要发送注册邮件并验证短信。对这两个操作的处理方式有两种:串行及并行。




(1)串行方式:新注册信息生成后,先发送注册邮件,再发送验证短信;





在这种方式下,需要最终发送验证短信后再返回给客户端。




(2)并行处理:新注册信息写入后,由发短信和发邮件并行处理;





在这种方式下,发短信和发邮件 需处理完成后再返回给客户端。




假设以上三个子系统处理的时间均为50ms,且不考虑网络延迟,则总的处理时间:




串行:50+50+50=150ms 

并行:50+50 = 100ms


若使用消息队列:





并在写入消息队列后立即返回成功给客户端,则总的响应时间依赖于写入消息队列的时间,而写入消息队列的时间本身是可以很快的,基本可以忽略不计,因此总的处理时间相比串行提高了2倍,相比并行提高了一倍;




2.2 应用耦合



具体场景:用户使用QQ相册上传一张图片,人脸识别系统会对该图片进行人脸识别,一般的做法是,服务器接收到图片后,图片上传系统立即调用人脸识别系统,调用完成后再返回成功,如下图所示:





该方法有如下缺点:




人脸识别系统被调失败,导致图片上传失败;


延迟高,需要人脸识别系统处理完成后,再返回给客户端,即使用户并不需要立即知道结果;


图片上传系统与人脸识别系统之间互相调用,需要做耦合;




若使用消息队列:





客户端上传图片后,图片上传系统将图片信息如uin、批次写入消息队列,直接返回成功;而人脸识别系统则定时从消息队列中取数据,完成对新增图片的识别。


此时图片上传系统并不需要关心人脸识别系统是否对这些图片信息的处理、以及何时对这些图片信息进行处理。事实上,由于用户并不需要立即知道人脸识别结果,人脸识别系统可以选择不同的调度策略,按照闲时、忙时、正常时间,对队列中的图片信息进行处理。




2.3 限流削峰



具体场景:购物网站开展秒杀活动,一般由于瞬时访问量过大,服务器接收过大,会导致流量暴增,相关系统无法处理请求甚至崩溃。而加入消息队列后,系统可以从消息队列中取数据,相当于消息队列做了一次缓冲。





该方法有如下优点:




请求先入消息队列,而不是由业务处理系统直接处理,做了一次缓冲,极大地减少了业务处理系统的压力;


队列长度可以做限制,事实上,秒杀时,后入队列的用户无法秒杀到商品,这些请求可以直接被抛弃,返回活动已结束或商品已售完信息;


扫描二维码推送至手机访问。

版权声明:本文由创想互联IM聊天系统发布,如需转载请注明出处。

本文链接:https://im.fofo.club/blog/post/42.html

分享给朋友:

“消息队列对即时通讯软件场景的重要性!” 的相关文章

IM即时通讯聊天软件交友朋友圈软件app定制开发

IM即时通讯聊天软件交友朋友圈软件app定制开发

随着社交网络的普及,即时通讯成为人们日常生活中非常重要的一部分。因此,即时通讯APP的开发也成为了一个非常热门的领域。本篇文章将会围绕即时通讯APP的开发流程进行阐述。需求分析首先,需要确定即时通讯APP的目标用户、功能需求、界面设计、技术方案等。在确定这些方面的要求后,才能进行下一步的设计和开发工...

即时通讯开发搭建哪家im通讯系统会比较稳定?

即时通讯开发搭建哪家im通讯系统会比较稳定?

   如果您正想搭建一套通讯系统,市面太多的通讯软件选择,琳琅满目,有自研通讯层,也有第三方,也有破解别人的,改不动重要的东西,只能搞搞搭建,反正坑是非常的多,一不小心就掉入陷阱,90%的公司是没有技术的,而且不可能有服务了,因为压根就没有参与开发,所以只能低价去吸引客户,当然这...

开发一款即时通讯APP要注意哪些事项

开发一款即时通讯APP要注意哪些事项

用户隐私和数据安全:保护用户的隐私和数据安全是至关重要的。确保用户的聊天内容和个人信息得到适当的加密和保护,采取措施防止未经授权的访问和数据泄露。实时性和性能:即时通讯App的核心功能是实时交流,因此应该注重实时性和性能。确保消息的快速传递和接收,减少延迟,并进行有效的性能优化,以提供流畅的用户体验...

安卓apk包没有上架的情况下,出现apk报毒该如何处理?

安卓apk包没有上架的情况下,出现apk报毒该如何处理?

这是很多app开发者都会遇到的问题,对于用户来说,如果应用出现报错、无法使用等情况,那么就会很影响体验;而对于开发者来说呢?否则可能会导致一些不必要的损失。公司开发的APP最近一直提示有风险软件、有病毒,在华为、OPPO等自带手机管家也报毒,经过几天的研究终于解决了,在腾讯和360检测都没什么问题了...

制作开发共享屏幕APP让会议更方便

制作开发共享屏幕APP让会议更方便

有很多东西正在悄悄变化,企业办公的方式也出现新的模式。共享屏幕APP制作开发主要为企业移动会议服务,不仅能提供高分辨率的画质,还会保障会议的安全,所有内容都是进行加密,不会轻易泄露。制作开发共享屏幕APP让会议更方便--广州app开发制作开发共享屏幕APP功能特色介绍1.   ...

同屏共享APP 的开发需要什么功能?同屏共享APP的开发需要多少钱?

同屏共享APP 的开发需要什么功能?同屏共享APP的开发需要多少钱?

随着科技的发展,人们的技术也在进步,人们参加会议的时候会使用到一些屏幕共享软件,借此来提高整体的效率。屏幕共享APP的开发就是为了帮助人们在参加远程会以的时候把数据矢量化,让回放不成问题。屏幕共享APP开发的功能介绍:1、 远程控制:屏幕共享平台会提供给用户远程控制的功能,在白板上的内容可以进行实时...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。