【面试宝典】39道RabbitMQ高频题库整理(附答案背诵版)

简述为什么要使用 RabbitMQ ?

使用RabbitMQ的原因主要有以下几点:

  1. 异步处理:RabbitMQ允许我们异步处理请求,这样可以缓解系统的压力,提高系统的可用性和响应性能。
  2. 解耦:通过使用RabbitMQ作为中间件,可以将各个系统解耦,减少系统间的直接依赖,降低系统间的耦合度。例如,在电商应用中,用户创建订单后,订单系统可以将订单信息发送到RabbitMQ,然后库存系统、物流系统和支付系统等都可以从RabbitMQ中获取订单信息并处理。如果某个系统出现故障,也不会影响到其他系统的正常运行。
  3. 流量削峰:在订单处理等场景中,可能会出现短时间内大量用户下单的情况。通过使用RabbitMQ作为缓冲层,可以将这些订单请求分散成一段时间来处理,避免系统在峰值时过载。
  4. 数据持久化:RabbitMQ支持消息持久化,这样就可以保证即使在系统重启或者故障的情况下,未完成的任务也不会丢失,可以继续被处理。
  5. 消息通信协议和规则的灵活性:RabbitMQ支持多种消息通信协议和规则,例如AMQP、STOMP和MQTT等,可以满足不同应用程序的需求。
  6. 可扩展性:RabbitMQ可以轻松地扩展到多个节点和服务器,以支持大规模的消息处理。
  7. 易用性:RabbitMQ提供了丰富的客户端库和API,可以方便地集成到应用程序中。

总之,使用RabbitMQ可以带来很多好处,包括提高系统的可用性、响应性能和解耦等。

简述RabbitMQ的组织架构 ?

RabbitMQ的组织架构包括以下几个主要组件:

  1. 服务器:RabbitMQ服务器是RabbitMQ的核心组件,负责管理所有的交换器和队列。一个RabbitMQ实例可以包含多个服务器,每个服务器负责一部分交换器和队列。服务器之间通过HTTP协议通信,可以使用多种方式进行部署,如单机、集群、云服务等。
  2. 交换器:交换器是RabbitMQ中的消息传递核心,负责接收、路由、传递消息。RabbitMQ支持多种交换器类型,如fanout、direct、topic等,每种类型的交换器都有不同的消息传递方式和应用场景。
  3. 队列:队列是RabbitMQ中的消息存储容器,用于存储消息。RabbitMQ支持多种队列类型,如持久化、非持久化、排他访问等,每种类型的队列都有不同的存储方式和应用场景。

此外,RabbitMQ由Producer、Broker、Consumer三个大模块组成。生产者将数据发送到Broker,Broker接收到数据后,将数据存储到对应的Queue里面,消费者从不同的Queue消费数据。除了Producer、Broker、Queue、Consumer、ACK这几个消息队列的基本概念外,RabbitMQ还有Exchange、Bind、Route这几个独有的概念。

简述RabbitMQ的优点 ?

RabbitMQ的优点主要包括:

  1. 消息解耦:使用RabbitMQ作为中间件,可以将各个系统解耦,减少系统间的直接依赖,降低系统间的耦合度。通过应用解耦,提升容错性和可维护性。
  2. 异步处理:将不需要同步处理的并且耗时长的操作由消息队列通知消息接收方进行异步处理。使用RabbitMQ以后,可以将耗时的操作异步化,提高应用程序的响应时间,从而提高用户体验和系统吞吐量。
  3. 削峰填谷:在订单处理等场景中,可能会出现短时间内大量用户下单的情况。通过使用RabbitMQ作为缓冲层,可以将这些订单请求分散成一段时间来处理,避免系统在峰值时过载。
  4. 消息持久化:RabbitMQ支持消息持久化,这样就可以保证即使在系统重启或者故障的情况下,未完成的任务也不会丢失,可以继续被处理。
  5. 多种通信协议和规则:RabbitMQ支持多种消息通信协议和规则,例如AMQP、STOMP和MQTT等,可以满足不同应用程序的需求。
  6. 可扩展性:RabbitMQ可以轻松地扩展到多个节点和服务器,以支持大规模的消息处理。
  7. 易用性:RabbitMQ提供了丰富的客户端库和API,可以方便地集成到应用程序中。

总之,RabbitMQ作为一种常用的消息中间件,具有许多优势,可以带来很多好处,包括提高系统的可用性、响应性能和解耦等。

简述RabbitMQ的缺点 ?

RabbitMQ的缺点主要包括:

  1. 系统可用性降低:系统引入的外部依赖增多,系统的稳定性就会变差。一旦RabbitMQ宕机,就会对业务产生影响。需要考虑如何保证RabbitMQ的高可用。
  2. 系统的复杂度提高:引入RabbitMQ后系统的复杂度会大大提高。以前服务之间可以进行同步的服务调用,引入RabbitMQ后,会变成异步调用,数据链路会变得更复杂。并且还会带来一系列的问题。

简述Exchange交换器的类型 ?

RabbitMQ的Exchange(交换器)分为四种类型:direct(默认)、fanout、topic、headers。

  1. Direct Exchange:这是RabbitMQ的模式,将Exchange和队列绑定的时候,需要指定路由键,并且在发消息的时候也需要指定路由键,并且路由键必须要完全一致。例如指定了路由键是green,那么只有与exchange绑定并且路由键为green的队列才会收到消息。
  2. Fanout Exchange:这是最简单的一种交换器。要注意的是fanout、topic交换器是没有历史数据的,也就是说对于中途创建的队列,获取不到之前的消息。
  3. Topic Exchange:这种类型的交换器与Direct Exchange基本相同,它们的路由键都可以进行匹配,但是Topic exchange的路由键可以进行模糊匹配。

除此之外,还有一种headers交换器,它允许你匹配AMQP消息的header而非路由键。不过headers交换器的性能很差,几乎用不到。

以上是RabbitMQ中Exchange的四种类型,它们各有特点,可以根据实际的使用场景进行选择。

简述RabbitMQ消息发送过程 ?

RabbitMQ的消息发送过程包括以下步骤:

  1. 生产者连接到RabbitMQ服务器,并创建一个通道。
  2. 生产者声明一个交换器,并设置相关属性,比如交换机类型、是否持久化、是否自动删除、是否内置等。
  3. 生产者声明一个队列并设置相关属性,比如是否排他、是否持久化、是否自动删除、消息最大过期时间、消息最大长度、消息最大字节数等。
  4. 生产者通过路由键将交换器和队列绑定起来。
  5. 生产者发送消息至RabbitMQ服务器,发送的消息包含消息体和含有路由键、交换器、优先级、是否持久化、过期时间、延时时间等信息的标签。
  6. 相应的交换器根据接收到的路由键查找相匹配的队列。如果找到,则将从生产者发送过来的消息存入相应的队列中;如果没有找到,则根据生产者配置的属性选择丢弃还是回退给生产者。

简述RabbitMQ消息接受过程 ?

RabbitMQ的消息接受过程包括以下步骤:

  1. 消费者连接到RabbitMQ服务器,并创建一个通道。
  2. 消费者声明一个队列并设置相关属性,比如是否持久化、是否自动删除等。
  3. 消费者订阅该队列,然后开始接收消息。
  4. 消费者接收到消息后,会根据自己对消息的处理对RabbitMQ进行返回。如果返回Ack,就表示已经确认这条消息,RabbitMQ会对这条消息进行处理(一般是删除);如果消费者收到消息后处理不了,或者崩溃了,就可能不能对RabbitMQ做出返回,或者拒绝对消息处理,返回reject,RabbitMQ在一定时间没收到返回或者收到reject后,会重新派遣消息。

简述RabbitMQ五种模式 ?

RabbitMQ的五种模式分别是:

  1. 简单队列模式:一个生产者对应一个消费者。
  2. 工作队列模式:一个生产者对应多个消费者,但是一条消息只能有一个消费者获得。
  3. 发布/订阅模式:一个消费者将消息首先发送到交换器,交换器绑定到多个队列,然后被监听该队列的消费者所接收并消费。
  4. 路由模式:生产者将消息发送到direct交换器,在绑定队列和交换器的时候有一个路由key,生产者发送的消息会指定一个路由key,那么消息只会发送到相应key相同的队列,接着监听该队列的消费者消费消息。也就是让消费者有选择性的接收消息。
  5. 主题模式:生产者将消息发送到Topic交换器,在绑定队列和交换器的时候有一个路由key,生产者发送的消息会指定一个路由key,那么消息只会发送到相应key相同的队列,接着监听该队列的消费者消费消息。也就是让消费者有选择性的接收消息。

简述RabbitMQ 消息基于什么传输 ?

RabbitMQ的消息基于AMQP(高级消息队列协议)进行传输。它是一种可靠、灵活、可扩展的消息传递机制,广泛应用于各行各业。

简述什么是RabbitMQ的Exchange ?

RabbitMQ的Exchange是消息队列服务器实体,用于发送消息。它是AMQP协议的核心组件之一,类似于一个交换机,将各个消息分发到对应的队列中。根据路由规则,Exchange将接收到的消息路由到一个或多个队列。Exchange的类型包括Direct、Fanout、Topic和Headers,每种类型有不同的路由规则和特点。

简述RabbitMQ的topic主题模式 ?

RabbitMQ的Topic主题模式是一种基于主题的消息传递模式。它允许发送者向一个特定的主题(topic)发布消息,同时,订阅者也可以针对自己感兴趣的主题进行订阅。在Topic模式中,主题通过一个由单词和点号组成的字符串来描述。

与Direct模式相比,Topic模式在消息路由方面有所不同。在Direct模式中,消息的路由是通过RoutingKey来完成的,而Topic模式允许队列在绑定Routing key 的时候使用通配符。这使得Topic模式在处理类似关键字分类消息时更加灵活和方便。

在Topic模式中,发送者和订阅者可以动态地绑定和解绑主题,实现动态的消息订阅和发布。这种灵活性使得Topic模式适用于发布/订阅、路由和负载均衡等场景。

总之,RabbitMQ的Topic主题模式提供了一种基于主题的消息传递方式,适用于多种应用场景,使得发送者和订阅者能够灵活地处理消息的发布和订阅。

RabbitMQ 上的queue 中存放的 message 是否有数量限制?

RabbitMQ本身没有明确的消息数量限制,实际上,这取决于你的系统硬件和配置。然而,如果你指的是队列中的消息数量,那么队列中的消息数量是有限制的的,这个限制取决于你的RabbitMQ服务器配置。

在RabbitMQ中,你可以通过设置queue的属性来控制队列中的消息数量。例如,你可以设置队列的最大长度(max-length)或最大内存使用量(memory)。当队列中的消息数量达到这些限制时,RabbitMQ将根据其配置决定如何处理新的消息。

需要注意的是,RabbitMQ不提供队列中消息数量的实时统计,这意味着你需要在你的应用程序中实施自己的消息计数策略。

总的来说,虽然RabbitMQ本身没有明确的消息数量限制,但你应该注意你的系统硬件和配置的限制,并在应用程序中实施适当的消息计数和限制策略,以避免出现问题。

简述RabbitMQ的routing路由模式 ?

RabbitMQ的Routing路由模式是一种消息路由方式,它基于消息的RoutingKey与队列的BindingKey进行匹配,将消息路由到正确的队列。

在Routing模式中,发送者在发送消息时需要指定一个RoutingKey,而接收者在绑定队列到交换器时也需要指定一个BindingKey。交换器根据RoutingKey和BindingKey的匹配情况将消息路由到正确的队列。

这种路由模式需要发送者和接收者之间建立明确的匹配关系,因此它适用于需要精确路由的场景。同时,由于RoutingKey和BindingKey的匹配规则是静态的,因此这种路由模式也适用于路由规则不经常变化的场景。

相比之下,Fanout模式和Topic模式适用于需要广播或主题方式路由消息的场景,而Headers模式则适用于需要使用自定义路由规则的场景。

总之,RabbitMQ的Routing路由模式适用于需要精确路由且路由规则不经常变化的场景。

简述RabbitMQ的发布与订阅模式 ?

RabbitMQ的发布与订阅模式是一种消息通信模式,其中发送者和接收者之间没有明确的匹配关系,而是通过发布/订阅主题进行消息传递。在这种模式下,发送者发布消息到特定的主题,而接收者订阅感兴趣的主题并接收消息。

在发布与订阅模式中,发布者不需要知道接收者的信息,而接收者也不需要知道发布者的信息。这种去耦的方式使得消息通信更加灵活和可扩展。

在RabbitMQ中,发布与订阅模式是通过Exchange和Queue的组合来实现的。Exchange是消息传递的核心组件,它负责接收发布者发送的消息并根据其类型和配置将消息路由到正确的队列。Queue是消息的存储容器,它负责缓存消息并保证消息的可靠传递。

在发布与订阅模式中,发布者将消息发送到Exchange,并使用一个或多个RoutingKey来指定消息的主题。Exchange根据RoutingKey和自己的配置将消息路由到对应的队列。同时,接收者可以订阅一个或多个队列,并监听这些队列中的消息。当队列中有新的消息时,RabbitMQ会将消息推送给接收者。

这种模式的优点是灵活性高、易于扩展和维护。发布者和接收者之间没有硬性匹配关系,使得应用程序之间的耦合度降低。同时,通过使用不同的Exchange和队列类型以及路由规则,可以实现多种不同的消息传递场景。

总之,RabbitMQ的发布与订阅模式是一种灵活的消息通信方式,适用于需要实现异步、解耦和可扩展的应用场景。

简述RabbitMQ的Work模式 ?

RabbitMQ的Work模式是一种简单的消息队列模式,也叫做“竞争消费者模式”或“任务分发模式”。在这种模式下,多个消费者同时监听同一个队列,当队列中有消息时,多个消费者之间会进行竞争,只有一个消费者能够获得这个消息并进行处理。其他消费者则需要等待下一个消息的到来。

在这种模式下,RabbitMQ允许多个消费者同时监听同一个队列,并且每个消费者只能接收一条消息。这使得消息在执行过程中可以分布到多个消费者中,并且每个消费者可以执行自己的任务。这种模式广泛应用于分布式系统中的任务调度或者并行处理等场景中。

Work模式中的轮询分发是一种消息分配方式,即多个消费者从消息队列中获取消息的方式。消费者将以轮询的方式获取消息,也就是每个消费者按照顺序逐个接收消息。当一个消费者接收到一条消息后,会对这个消息进行处理,然后确认已经处理完成,随后再尝试获取下一条消息。如果当前消费者在处理消息时,消息队列对其它消费者进行了轮询派发,则消息队列会将该消息重新分配给其他消费者。

需要注意的是,在Work模式下,生产者的消息是发送到一个队列里,所以即使有两个消费者,一个消息只能被一个消费者消费。同时,Work模式中可以分为两种模式:一两个消费者平均消费队列中的消息,即使它们的消费能力是不一样的;二能者多劳模式,消费能力强的消费者会获取更多的消息。

由于内容太多,更多内容以链接形势给大家,点击进去就是答案了

16. 简述RabbitMQ的Simple模式 ?

17. 简述什么是RAM node 和 Disk node 的区别?

18. 简述什么是RabbitMQ Broker?

19. 简述什么是RabbitMQ Binding ?

20. 简述RabbitMQ的Exchange有几种模式 ?

21. RabbitMQ如何保证消息队列丢数据消息不丢失( 队列稳定性 )?

22. RabbitMQ如何保证生产者丢数据消息不丢失 ?

23. RabbitMQ如何保证消息不被重复消费?

24. RabbitMQ消息接收确认过程?

25. RabbitMQ消息发送确认过程?

26. 简述什么是RabbitMQ延迟队列 ?

27. 简述什么是RabbitMQ优先级队列 ?

28. 简述RabbitMQ队列结构?

29. RabbitMQ消息如何被优先消费?

30. RabbitMQ消息是如何路由的?

31. RabbitMQ如何保证消费者丢数据消息不丢失 ?

32. RabbitMQ如何保证消息的有序性?

33. 解释列举RabbitMQ消息堆积的原因?

34. 简述恢复RabbitMQ队列中丢失的数据 ?

35. 如何自动删除长时间没有消费的RabbitMQ消息?

36. RabbitMQ消息传输保证层级?

37. 简述RabbitMQ的镜像队列集群模式 ?

38. 简述RabbitMQ的普通集群模式 ?

39. 如何保证高可用 - RabbitMQ 集群 ?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值