消息队列入门了解

1. 什么是MQ?

  消息队列(MQ),是一种应用程序对应用程序的通信方法。应用程序通过写和检索出入列队的针对应用程序的数据(消息)来通信,而无需专用连接来链接它们。
  消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。

2. 为什么要用消息队列?

 a:异步处理。
    程序中的非依赖关系的功能,如日志的收集,直接将需要处理的日志,丢到消息队列中。
 b:系统解耦。
    将直接调用,变为A->mq,mq->B。A,B服务是相互独立的,减少相互的影响
 c:流量消峰。
    当流量比较大的时候,如果下游系统无法处理瞬间的大流量,会导致系统的cpu等资源紧张,进而拖垮整个系统。使用消息队列,可以将上游瞬间的流量产生的消息放在mq,消费者可以根据自己的消费能力处理队列中的数据,这样系统整体处理流量比较平稳进行展示;

3.消息队列的缺点?

 a:系统可用性降低:
    他系统只要运行好好的,那你的系统就是正常的。现在你非要加个消息队列进去,那消息队列挂了,因此,系统可用性降低。
 b:系统复杂性提高:
    硬生生加个MQ进来,你怎么保证消息没有重复消费?怎么处理消息丢失的情况? 怎么保证消息传递的顺序性?头大头大,问题一大堆,痛苦不已。
 c:一致性问题:
    A系统处理完了直接返回成功了,人都以为你这个请求就成功了;
 但是问题是,要是BCD三个系统那里,BD两个系统写库成功了,结果C系统写库失败了,咋整?你这数据就不一致了。

4.kafka、activemq、rabbitmq、rocketmq都有什么优点和缺点?

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值