RabbitMQ 面试题

RabbitMQ 的使用场景有哪些?
  • 1、跨系统的异步通信,所有需要异步交互的地方都可以使用消息队列,就像我们除了到电话(同步)以外,还需要发短信、发电子邮件(异步)等通讯方式。
  • 2、多个应用之间的耦合,由于消息是平台无关和语言无关的,而且语义上也不再是函数调用,因此更适合作为多个应用之间的松耦合的接口,基于消息队列的耦合,不需要发送方和接收方同时在线,在企业应用集成(EAI)中,文件传输,数据库共享,消息队列,远程过程调用都可以作为集成的方法。
  • 3、应用的同步变异步,比如订单处理,就可以有前端应用将订单信息放入队列,后端应用从队列里依次获得消息处理,高峰时的大量订单可以积压在队列里慢慢处理掉,由于同步通常意味着阻塞,而大量线程的阻塞会降低计算机的性能。
  • 4、消息驱动的架构(EDA),系统分为消息队列和消息制造者和消息消费者,一个处理流程可以根据需要拆成多个阶段(Stage),阶段之间用队列连接起来,前一个阶段处理的结果放入队列,后一个阶段从队列中获取消息继续处理。
  • 5、应用需要更灵活的耦合方式,如发布订阅,比如可以指定路由规则。
  • 6、跨局域网,甚至跨城市的通讯(CDN行业),比如北京机房与广州机房的应用程序通信。
RabbitMQ 有哪些重要的角色?
  • RabbitMQ中重要的角色分别有:生产者、消费者、代理。
    1)生产者:消息的创建者,负责创建和推送数据到消息服务器。
    2)消费者:消息的接收方,用于处理数据和确认消息。
    3)代理:就是RabbitMQ的本身,用于扮演“快递”的角色,本身不生产消息,只是扮演“快递”的角色。
RabbitMQ 有哪些重要的组件?
  • ConnectionFactory(连接管理器):应用程序与Rabbit之间建立连接的管理,程序代码中使用。
  • Channel(信道):消息推送的通道。
  • ExChange(交换器):用于接收,跟配消息。
  • Queue(队列):用于存储生产者的消息。
  • RoutingKey(路由键):用于把生产者的数据分配到交换器上。
  • BindingKey(绑定键):用于把交换器的消息绑定到队列上。
RabbitMQ 中 vhost 的作用是什么?
  • vhost可以理解为虚拟broker,即mini-RabbitMQ Server。其内部均还有独立的Queue、Exchange和Binding等。但最最重要的是,,其拥有独立的权限系统,可以做到vhost范围的用户控制,当然,从RabbitMQ的全局角度,vhost可以作为不同权限隔离的手段(一个典型的例子就是不同的应用可以炮座不同的vhost中)。
RabbitMQ 的消息是怎么发送的?
  • 首先客户端必须连接到RabbitMQ服务器才能发布的消费信息,客户端和Rabbit Server之间会简历一个TCP连接,一旦TCP打开并通过了认证(认证是你发送给Rabbit 服务器的用户名和密码),你的客户端和RabbitMQ就创建了一条amqp信道,(Channel),信道是创建“真是”TCP上的虚拟连接,amqp命令都是通过信道发送出去的,每个信道都会有一个唯一的ID,无论是发布消息,订阅队列都是通过这个信道完成的。
RabbitMQ 怎么保证消息的稳定性?
  • 提供了事务的功能。
  • 通过将Channel 设置为confirm(确认) 模式。
RabbitMQ 怎么避免消息丢失?
  • 消息持久化、ACK确认机制、设置集群镜像模式、消息补偿机制。
要保证消息持久化成功的条件有哪些?

满足以下四个条件都才能保证消息持久化成功:

  • 声明队列必须设置持久化durable 设置为 true。
  • 消息推送投递模式必须设置为持久化,deliveryMode 设置为 2(持久)。
  • 消息一定到达持久化交换器。
  • 消息已经到达持久化队列。
RabbitMQ 持久化有什么缺点?
  • 持久化的缺点就是降低了服务器的吞吐量,因为使用的是磁盘而非内存存储,从而降低了吞吐量,可尽量使用ssd硬盘来缓解吞吐量的问题。
RabbitMQ 有几种广播类型?
  • 有 三种广播模式:
    1)fanout:所有bind到exchange都可以接收消息(纯广播,丙丁RabbitMQ的接受者都能收到消息)。
    2)direct:通过Routingkey和Exchange觉得的那个唯一的Queue可以接收消息。
    3)topic:所有符合RoutingKey(此时可以是一个表达式)的RoutingKey锁bind的Queue可以接收消息。
RabbitMQ 怎么实现延迟消息队列?
  • 通过消息过期后进入信道交换器,再有交换器发到延迟消费队列,实现延迟功能。
  • 使用RabbitMq-delayed-message-exchange 插件实现延迟功能。
RabbitMQ 集群有什么用?
  • 集群主要有一下两个用途:
    1)高可用:某个服务器出现问题,整个RabbitMQ还可以继续使用。
    2)高容量:集群可以承载更多的消息量。
RabbitMQ 节点的类型有哪些?
  • 磁盘节点:消息会存储到磁盘。
  • 内存节点:消息都存储在内存中,重启服务器消息丢失,性能高于磁盘类型。
RabbitMQ 集群搭建需要注意哪些问题?
  • 各节点之间是用“–link”连接,此属性不能忽略。
  • 各节点使用的erlang cookie 值必须相同,此值相当于秘钥的功能,用于各节点的认证。
  • 整个集群中必须包含一个磁盘节点。
RabbitMQ 每个节点是其他节点的完整拷贝吗?为什么?
  • 不是,原因有一下两个:
    1)存储空间的考虑,如果每个节点都拥有所有队列的完全拷贝,这样新增节点不但没有新增存储空间,反而增加了更多的冗余数据。
    2)性能的考虑:如果每条消息都需要拷贝到每一个集群节点,那新增节点并没有提升处理消息的能力,最多是保持和单节点相同的性能甚至更糟。
RabbitMQ 集群中唯一一个磁盘节点崩溃了会发生什么情况?

唯一磁盘节点奔溃了,集群是可以保持运行的,但你不能更改任何东西。

  • 1、不能创建队列。
  • 2、不能创建交换器。
  • 3、不能创建绑定。
  • 4、不能添加用户。
  • 5、不能更改权限。
  • 6、不能添加和删除集群节点。
RabbitMQ 对集群节点停止顺序有要求吗?

RabbitMQ 对集群的停止顺序是有要求的,应该先关闭内存节点,最后再关闭磁盘节点,如果顺序恰好相反的话,可能会造成消息的丢失。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值