什么是消息队列?

目录

什么是消息队列?

消息队列中间件

消息队列的应用场景

异步处理

系统解耦

流量削峰

日志处理


什么是消息队列?

消息队列,英文名:Message Queue,经常缩写为MQ。从字面上来理解,消息队列是一种用来存储消息的队列。来看一下下面的代码:

// 1. 创建一个保存字符串的队列
Queue<String> stringQueue = new LinkedList<String>();

// 2. 往消息队列中放入消息
stringQueue.offer("hello");

// 3. 从消息队列中取出消息并打印
System.out.println(stringQueue.poll());

上述代码,创建了一个队列,先往队列中添加了一个消息,然后又从队列中取出了一个消息。这说明了队列是可以用来存取消息的。

消息队列中间件

消息队列中间件就是用来存储消息的软件(组件)。举个例子来理解,为了分析网站的用户行为,我们需要记录用户的访问日志。这些一条条的日志,可以看成是一条条的消息,我们可以将它们保存到消息队列中。将来有一些应用程序需要处理这些日志,就可以随时将这些消息取出来处理。

目前市面上的消息队列有很多,例如:Kafka、RabbitMQ、ActiveMQ、RocketMQ、ZeroMQ等。

 目前的吞吐量上面,kafka是这些中间件的做得最好

消息队列的应用场景

异步处理

电商网站中,新的用户注册时,需要将用户的信息保存到数据库中,同时还需要额外发送注册的邮件通知、以及短信注册码给用户。但因为发送邮件、发送注册短信需要连接外部的服务器,需要额外等待一段时间,此时,就可以使用消息队列来进行异步处理,从而实现快速响应。

系统解耦

原先是一个微服务通过接口(HTTP)调用另一个程序,这时候耦合很严重,只要接口发生变化就会导致系统不可用

比如订单系统和库存系统,如果库存系统出现了问题,那么订单系统就会出现问题,现在可以直接将数据存入消息队列,不再去关注库存怎么处理这些信息

流量削峰

当并发量过高的时候,mysql就会扛不住,这个时候就可以将数据先存入消息队列,然后再打到数据库

日志处理

可以用消息队列进行临时存储,或者一种通信管道

消息队列可以在日志产生时将日志消息发布到队列中,而不是直接写入日志文件。这样可以将日志处理与产生日志的系统解耦,提高系统的性能和可伸缩性。消费者可以异步地从队列中读取消息,并将其写入日志文件,可以按照优先级或特定规则对日志消息进行排序和处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ADRU

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值