面试题专题:MQ相关

144 阅读4分钟

小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。

摘要

本次分享面试题专题均为自己21届校招时通过牛客以及自己面试遇到的问题,答案均为自己理解整理,如果有错误,请麻烦评论指出,万分感谢,如对您有所帮助,请交出您的三连或者点赞也是爱♥

Mq的作用

1)解耦 : 中间件中的生产者只管发送消息 , 消费者只要从队列当中获取消息进行消费 就可以 , 从而来实现业务的解耦 。

2)冗余存储 : 有些情况下,处理数据的过程会失败。消息中间件可以把数据进行持久化直到它们已经被完全处理,通过这一方式规避了数据丢失风险。在把一个消息从消息中间 件中删 除之前,需要你的处理系统明确地指出该消息己经被处理完成,从而确保你的数据 被安全地保 存直到你使用完毕。

3)可恢复性: 当系统一部分组件失效时,不会影响到整个系统 。 消息中间件降低了进程间的 稿合度,所以即使一个处理消息的进程挂掉,加入消息中间件中的消息仍然可以在系 统恢复后 进行处理 。

4)顺序保证: 在大多数使用场景下,数据处理的顺序很重要,大部分消息中间件支持一 定程 度上的顺序性。

5)缓冲: 在任何重要的系统中,都会存在需要不同处理时间的元素。消息中间件通过一 个缓 冲层来帮助任务最高效率地执行,写入消息中间件的处理会尽可能快速 。

6)异步通信: 在很多时候应用不想也不需要立即处理消息 。 消息中间件提供了异步处 理机制,允许应用把一些消息放入消息中间件中,但并不立即处理它,在之后需要的时候再 慢慢处理 。

rabbitmq 的使用场景有哪些?

①. 跨系统的异步通信,所有需要异步交互的地方都可以使用消息队列。就像我们除了打电话(同步)以外,还需要发短信,发电子邮件(异步)的通讯方式。

②. 多个应用之间的耦合,由于消息是平台无关和语言无关的,而且语义上也不再是函数调用,因此更适合作为多个应用之间的松耦合的接口。基于消息队列的耦合,不需要发送方和接收方同时在线。在企业应用集成(EAI)中,文件传输,共享数据库,消息队列,远程过程调用都可以作为集成的方法。

③. 应用内的同步变异步,比如订单处理,就可以由前端应用将订单信息放到队列,后端应用从队列里依次获得消息处理,高峰时的大量订单可以积压在队列里慢慢处理掉。由于同步通常意味着阻塞,而大量线程的阻塞会降低计算机的性能。

④. 消息驱动的架构(EDA),系统分解为消息队列,和消息制造者和消息消费者,一个处理流程可以根据需要拆成多个阶段(Stage),阶段之间用队列连接起来,前一个阶段处理的结果放入队列,后一个阶段从队列中获取消息继续处理。

⑤. 应用需要更灵活的耦合方式,如发布订阅,比如可以指定路由规则。

⑥. 跨局域网,甚至跨城市的通讯(CDN行业),比如北京机房与广州机房的应用程序的通信。

rabbitmq 有哪些重要的角色?

RabbitMQ 中重要的角色有:生产者、消费者和代理:

  • 生产者:消息的创建者,负责创建和推送数据到消息服务器;
  • 消费者:消息的接收方,用于处理数据和确认消息;
  • 代理:就是 RabbitMQ 本身,用于扮演“快递”的角色,本身不生产消息,只是扮演“快递”的角色。
  • 消息:消息,消息是不具名的,它由消息头和消息体组成。消息体是不透明的,而消息头则由一系 列的可选属性组成,这些属性包括 routing-key(路由键)、priority(相对于其他消息的优 先权)、delivery-mode(指出该消息可能需要持久性存储)等。