案例16-消息队列的作用和意义

简介: 消息队列的作用和意义

一、什么是消息队列

       在学习消息队列之前,先说一下什么是队列。队列可以说是一个数据结构,可以存储数据,如下图,我们从右侧(队尾)插入元素(入队),从队头获取元素(出队)。

47e9c93988f041b99e7cd94ef3e8f460.png

       了解了队列之后,我们来看一下什么是消息队列,消息队列就是我们常说的MQ,英文叫Message Queue,是作为一个单独的中间件产品存在的,独立部署。

9bc002b445a14cf7bec65f6374ca8ca2.png

二、为什么使用消息队列

1.解耦

1127bcba73e84a949905b3c02bc61d01.png

       使用MQ之前,系统A产生消息系统B和系统C需要系统A的消息,那么就需要系统A去调用系统B和系统C,这样如果再来一个系统D也需要这个消息,就需要修改系统A中的代码。然后测试上线。如果有一天系统B不需要系统A中的消息了,那么还是需要修改系统A中的代码。在修改的过程中还需要考虑会不会影响其他的系统,修改完毕之后测试然后再上线。这样维护系统A的人就会很烦。

       使用MQ之后,系统A只需要负责把消息放到MQ中就不需要管了。也不需要考虑是不是有新的系统需要这个消息,也不需要考虑谁不用了。完全交给MQ去做。系统A和其他系统之间的耦合降低了。

2.异步

Data newData = productData();//系统A经过一些逻辑处理后产生了数据,耗时200ms  
Response responseB = callSysB(newData);//系统A调系统B接口发送数据,耗时300ms 
Response responseC = callSysC(newData);//系统A调系统C接口发送数据,耗时300ms

       使用MQ之前,系统A产生了一条数据,然后先调用系统B的接口发送数据,然后调用系统C的接口发送数据,最后调用系统D的接口发送数据。200+300+300=800ms。这就会导致响应的非常慢。

Data newData = productData();//系统A经过一些逻辑处理后产生了数据,耗时200ms 
writeDataToMQ(newData);//往MQ里写消息,耗时50ms

       使用MQ之后,系统A产生了一条数据,直接交给MQ就可以了。系统B和系统C自己去MQ中拿慢慢消费就可以了。200+50=250ms。250ms用户就可以得到结果。

3.削峰

       我们大家都知道双十一淘宝京东都会搞活动。双十一这一天会把平时的流量高出几十倍几百倍。如果没有使用MQ下单的信息直接实时操作数据库,就会导致数据库承受的压力太大。数据库挂掉整个系统就不能使用了。如果使用MQ下单的数据只需要往MQ里发送消息,我的订单系统可以设定消费的频率,比如每秒我就消费2000个消息(在数据库的可承受范围),不管你下游系统每秒下多少单,我都保持这个速率,既不会影响我订单系统的数据库,也不影响你下游系统的下单操作,很好的保护了系统。剩余的消息慢慢消费就可以了。

三、如何使用消息队列

1.添加RabbitMQ的依赖

<!--        amqp依赖,包含RabbitMQ-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>

2.添加ReabbitMq配置

spring
    rebbitmq:
        host:IP地址
        port:端口号
        virtual:/
        username:guest
        password:guest

3.编写消息生产者

f7312db8657e43408ae649b362d26a59.png

4.编写消息消费者

bcc39828b40444338d106d052ad81d55.png

5.测试类

@Autowired
    private SpringMqProduceTest springMqProduceTest;
    @GetMapping("testMq/{message}")
    public String testMq(@PathVariable("message") String message){
        springMqProduceTest.testSimpleQueue("testMq",message);
        return "已发送:"+message;
    }

6.执行结果

6f9e6ee2e1854159a9f30cab58949ac4.png

四、总结提升

       RabbitMQ是一个功能强大且可靠的消息中间件,适用于各种场景,包括分布式系统、微服务架构、异步任务处理等。它提供了丰富的特性和灵活的配置选项,使得消息传递变得简单和可靠。        

       对于消息队列足够的了解我们在使用的过程中才会更加的得心应手。我们才能明确什么情况下应该使用消息队列。


相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
6月前
|
消息中间件 Java Spring
JavaWeb后端开发Spring框架之消息 消息队列案例--订单短信通知
JavaWeb后端开发Spring框架之消息 消息队列案例--订单短信通知
51 0
|
7月前
|
消息中间件 存储 中间件
【SpringCloud Stream消息驱动、设计思想以及整合rabbitmq消息队列案例--学习笔记】
【SpringCloud Stream消息驱动、设计思想以及整合rabbitmq消息队列案例--学习笔记】
283 0
|
消息中间件 运维 监控
消息队列和应用工具产品体系-完美日记电商业务案例
消息队列和应用工具产品体系-完美日记电商业务案例
消息队列和应用工具产品体系-完美日记电商业务案例
|
消息中间件 中间件 关系型数据库
【项目实战典型案例】16.消息队列作用和意义
【项目实战典型案例】16.消息队列作用和意义
|
消息中间件 中间件 关系型数据库
案例16-消息队列的作用和意义
案例16-消息队列的作用和意义
|
消息中间件 存储 前端开发
28个案例问题分析---16---消息队列的作用和意义--RabbitMq
28个案例问题分析---16---消息队列的作用和意义--RabbitMq
129 0
|
5月前
|
消息中间件 C语言 RocketMQ
消息队列 MQ操作报错合集之出现"Connection reset by peer"的错误,该如何处理
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
5月前
|
消息中间件 Java C语言
消息队列 MQ使用问题之在使用C++客户端和GBase的ESQL进行编译时出现core dump,该怎么办
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
1月前
|
消息中间件 存储 Kafka
MQ 消息队列核心原理,12 条最全面总结!
本文总结了消息队列的12个核心原理,涵盖消息顺序性、ACK机制、持久化及高可用性等内容。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
|
3月前
|
消息中间件
手撸MQ消息队列——循环数组
队列是一种常用的数据结构,类似于栈,但采用先进先出(FIFO)的原则。生活中常见的排队场景就是队列的应用实例。在数据结构中,队列通常用数组实现,包括入队(队尾插入元素)和出队(队头移除元素)两种基本操作。本文介绍了如何用数组实现队列,包括定义数组长度、维护队头和队尾下标(front 和 tail),并通过取模运算解决下标越界问题。此外,还讨论了队列的空与满状态判断,以及并发和等待机制的实现。通过示例代码展示了队列的基本操作及优化方法,确保多线程环境下的正确性和高效性。
48 0
手撸MQ消息队列——循环数组