初识MQ-同步异步

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、同步通讯
  • 二、异步通讯
    • 2.1.异步调用方案
    • 2.2.异步的优缺点
  • 三、什么时MQ
    • 3.1 mq和broker
    • 3.2几种mq的优缺点对比
  • 总结


前言

一、同步通讯

同步调用问题:发起请求后,要一直等待后续流程走完,才能执行下一个,效率慢,性能差,资源浪费

级联失败:如果执行过程中,其中一个出现问题,后续都无法走下去,
耦合度高:每次添加新需要,都需要改原来的代码
在这里插入图片描述

在这里插入图片描述

二、异步通讯

2.1.异步调用方案

服务解耦:当不需要某个模块时,直接通过broker取消对功能的订阅,后续就不会有该模块了,同理添加需求的时候也不需要改动支付模块

在这里插入图片描述
使用broker,当进行到支付成功时,直接返回给用户消息,不需要等待后续程序的执行
同步调用耗时:500ms(所有时间之和)
异步调用耗时:60ms(支付和发布支付成功事件)
在这里插入图片描述
使用broker,当进行到支付成功时,直接返回给用户消息,不需要等待后续程序的执行
在这里插入图片描述
**同时有大量的请求时,broker会将请求拦截下来,后面程序能处理多少,就放多少过去,其他都拦住,就不会出现流量突然很大的情况 **
在这里插入图片描述

2.2.异步的优缺点

在这里插入图片描述

三、什么时MQ

3.1 mq和broker

mq,中文消息队列,字面来看就是存放消息的队列,也就是时间驱动架构中的broker

3.2几种mq的优缺点对比

在这里插入图片描述

总结

大多数情况下,都是使用同步调用,如果对吞吐量等有要求的话,才能使用异步
四种mq都各有优劣,具体使用哪种看业务需求

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/417857.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring Boot框架中Controller层API接口如何支持使用多个@RequestBody注解接受请求体参数

一、前言 众所周知,在Spring Boot框架中,Controller层API接口编码获取请求体参数时,在参数上会使用RequestBody注解;如果一次请求中,请求体参数携带的内容需要用多个参数接收时,能不能多次使用RequestBody…

【从零到一AIGC源码解析系列1】文本生成图片Stable Diffusion的diffusers实现

目录 1. 如何使用 StableDiffusionPipeline 1.1环境配置 1.2 Stable Diffusion Pipeline 1.3生成非正方形图像 2. 如何使用 diffusers 构造自己的推理管线 关注公众号【AI杰克王】 Stable Diffusion是由CompVis、StabilityAl和LAION的研究人员和工程师创建的文本到图像潜在…

《Linux高性能服务器编程》笔记01

Linux高性能服务器编程 本文是读书笔记,如有侵权,请联系删除。 参考 Linux高性能服务器编程源码: https://github.com/raichen/LinuxServerCodes 豆瓣: Linux高性能服务器编程 文章目录 Linux高性能服务器编程第05章 Linux网络编程基础API5.1 socket…

【MySQL】——关系数据库标准语言SQL(大纲)

🎃个人专栏: 🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客 🐳Java基础:Java基础_IT闫的博客-CSDN博客 🐋c语言:c语言_IT闫的博客-CSDN博客 🐟MySQL&#xff1a…

从零开始配置vim(Windows版)

事情是这样的,之前linux下vim用习惯了...然后就给自己win下vscode也装了个vim插件,用下来还是感觉不顺手,并且处理太多文本时有明显卡顿,于是乎自己配了下win版的vim。 不过好像也并不是从零开始的...初始基础版的.vimrc有copy他们…

【前端设计】流光按钮

欢迎来到前端设计专栏,本专栏收藏了一些好看且实用的前端作品,使用简单的html、css语法打造创意有趣的作品,为网站加入更多高级创意的元素。 css body{height: 100vh;display: flex;justify-content: center;align-items: center;background…

16k+ start 一个开源的的监控系统部署教程

安装条件 Linux或macOS系统 4GB内存 开放 33014、33174、3183端口 1.安装 1、下载源码 首先使用 git 克隆源码到本地 git clone -b main https://github.com/SigNoz/signoz.git && cd signoz/deploy/ 方式1:运行 install.sh 脚本一键安装 ./install.s…

西瓜书读书笔记整理(十二) —— 第十二章 计算学习理论

第十二章 计算学习理论(上) 12.1 基础知识12.1.1 什么是计算学习理论(computational learning theory)12.1.2 什么是独立同分布(independent and identically distributed, 简称 i . i . d . i.i.d. i.i.d.&#xff0…

扩散模型:Diffusion Model原理剖析

Diffusion Model 视频Training 第5行是唯一需要解释的地方, x 0 x_{0} x0​ 是干净的图片, ϵ θ \epsilon _{\theta } ϵθ​是前面说的Noise Predictor,它的输入包括加噪声之后的图像(红色框)以及时序 t t t , ϵ \epsilon ϵ 是训练的target也就是添加的噪声。它其…

Java代码审计Shiro反序列化DNS利用链CC利用链AES动态调试

目录 0x00 前言 0x01 Java原生反序列化介绍 0x02 安全问题1:重写toString方法(打印对象时触发) 0x03 安全问题2:重写readObject(反序列化时触发) 0x04 测试URLDNS链 0x05 Shiro550生成RememberMe Coo…

数据结构【DS】Ch6 图

文章目录 图的基本概念图的存储及基本操作图的遍历图的应用图的连通性问题最小生成树最短路径问题拓扑序列关键路径 图的基本概念 图的存储及基本操作 图的遍历 图的应用 图的连通性问题 最小生成树 最短路径问题 拓扑序列 关键路径

GetShell的姿势

0x00 什么是WebShell 渗透测试工作的一个阶段性目标就是获取目标服务器的操作控制权限,于是WebShell便应运而生。Webshell中的WEB就是web服务,shell就是管理攻击者与操作系统之间的交互。Webshell被称为攻击者通过Web服务器端口对Web服务器有一定的操作权…