热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

举例说明一下消息队列的应用场景

消息队列是分布式系统中重要的组件,主要实现了:异步消息,应用解耦,流量控制等功能。应用场景1.异步处理以注册用户为例&

消息队列是分布式系统中重要的组件,主要实现了:异步消息,应用解耦,流量控制等功能。


应用场景


1.异步处理

以注册用户为例,

假设用户注册需要发送注册邮件,发送短信及数据入库

用户注册后 首先进行数据入库,入库后的两个操作通常有并行与串行两种执行方

1.串行:两个功能顺序执行,先发邮件后发短信,或先发短信后发邮件

2.并行:发短信和发邮箱两个功能同时异步执行,以上三个任务完成后,返回给客户端。

假设三个业务节点每个使用50毫秒钟,不考虑网络等其他开销,则串行方式的时间是150毫秒,并行的时间可能是100毫秒。

优化:

引入消息队列,将不是必须要的业务逻辑,入消息队列异步处理

优化后用户请求的响应时间降低为55ms



2.应用解耦

以电商下单为例

用户下单后,订单系统通知库存系统,对库存进行操作,传统的做法是订单系统调用库存系统的接口完成操作

 传统做法的缺点:

1)两系统之间存在耦合

2)若库存系统出现异常,将会导致订单系统同时出现异常,导致本次订单失效

引入消息队列

此时订单系统工作为:订单系统完成本职功能后,将此消息写入消息队列,即可返回下单成功

此时库存系统工作:订阅下单的消息信道,从信道中获取下单消息,进行库存操作

此时若库存系统发生故障,将不会影响到订单系统功能,订单系统照样可以接受用户下单,因为系统的解耦,订单系统只关心自己的业务,订单写入消息队列后的后续操作订单系统就不用再关心了


3.削峰填谷

以秒杀活动为例

秒杀活动的特点是短时流量暴增,导致服务器无法处理大量请求,引发响应过慢或服务宕机(一般影响最大的是mysql)

引入消息队列

1)缓解数据库压力,可将大量数据库的写操作入消息队列,消息队列再以数据库能接受的流量控制访问数据库(假设数据库每秒能处理100条SQL,秒杀期间每秒进入1000条SQL,活动期间的SQL请求大量堆积在消息队列中(削峰),消息队列再以100条每秒的流量访问数据库,待秒杀结束后流量恢复正常每秒10条,此时消息队列仍以每秒100条的流量向数据库请求(填谷))

2)控制请求数量

 用户的请求被接收后,先入消息队列,假设请求数量达到预设最大值,则抛弃掉后续进来的请求


推荐阅读
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 探讨架构师在项目中应如何平衡对产品的关注和对团队成员的关注,以实现最佳的开发成果。 ... [详细]
author-avatar
kg9854997
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有