案例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一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
6天前
|
消息中间件 存储 中间件
【SpringCloud Stream消息驱动、设计思想以及整合rabbitmq消息队列案例--学习笔记】
【SpringCloud Stream消息驱动、设计思想以及整合rabbitmq消息队列案例--学习笔记】
66 0
|
8月前
|
消息中间件 运维 监控
消息队列和应用工具产品体系-完美日记电商业务案例
消息队列和应用工具产品体系-完美日记电商业务案例
88 0
消息队列和应用工具产品体系-完美日记电商业务案例
|
10月前
|
消息中间件 中间件 关系型数据库
【项目实战典型案例】16.消息队列作用和意义
【项目实战典型案例】16.消息队列作用和意义
|
10月前
|
消息中间件 中间件 关系型数据库
案例16-消息队列的作用和意义
案例16-消息队列的作用和意义
|
10月前
|
消息中间件 存储 前端开发
28个案例问题分析---16---消息队列的作用和意义--RabbitMq
28个案例问题分析---16---消息队列的作用和意义--RabbitMq
87 0
|
消息中间件 Java 测试技术
JAVA应用开发MQ实战最佳实践——Series2:消息队列RocketMQ性能测试案例
JAVA应用开发MQ实战最佳实践——Series2:消息队列RocketMQ性能测试案例
JAVA应用开发MQ实战最佳实践——Series2:消息队列RocketMQ性能测试案例
|
6天前
|
消息中间件 存储 监控
RabbitMQ:分布式系统中的高效消息队列
RabbitMQ:分布式系统中的高效消息队列
|
6天前
|
消息中间件 分布式计算 监控
Python面试:消息队列(RabbitMQ、Kafka)基础知识与应用
【4月更文挑战第18天】本文探讨了Python面试中RabbitMQ与Kafka的常见问题和易错点,包括两者的基础概念、特性对比、Python客户端使用、消息队列应用场景及消息可靠性保证。重点讲解了消息丢失与重复的避免策略,并提供了实战代码示例,帮助读者提升在分布式系统中使用消息队列的能力。
42 2
|
6天前
|
消息中间件 Java
springboot整合消息队列——RabbitMQ
springboot整合消息队列——RabbitMQ
82 0