RabbitMQ 45 道面试题及答案.docx

preview
需积分: 0 0 下载量 65 浏览量 更新于2023-07-08 收藏 122KB DOCX 举报
RabbitMQ是一款基于AMQP(Advanced Message Queuing Protocol)的开源消息队列系统,它提供了高效、可靠的消息传递服务,广泛应用于服务间的异步通信、负载均衡、削峰填谷等多个场景。以下是对RabbitMQ相关知识点的详细解释: 1. **RabbitMQ的核心特性**: - 消费者无需在生产者存在时即可消费消息,实现服务解耦。 - 提供异步处理能力,允许在分布式系统中进行削峰填谷,提高系统响应速度。 - 支持消息持久化,即使服务宕机,也能保证消息的恢复。 - 通过消息队列实现消费者和生产者的解耦,降低两者之间的依赖性。 - 可用于限流,将高并发访问变为串行访问,保护数据库不受冲击。 2. **使用RabbitMQ的场景**: - **服务间异步通信**:允许服务间以非阻塞方式通信,提高系统吞吐量。 - **顺序消费**:通过特定配置,确保消息按顺序被消费。 - **定时任务**:配合插件实现定时发布消息,执行定时任务。 - **请求削峰**:在高并发场景下,消息队列可以缓解系统压力,防止服务崩溃。 3. **消息发送的可靠性**: - **发送方确认模式**:开启确认模式后,RabbitMQ会在消息投递或持久化后发送确认,如果发生错误则发送NACK。生产者可以通过回调处理确认或NACK。 - **接收方确认机制**:消费者需确认消息已被处理,RabbitMQ才会删除消息。未确认的消息会被重新分发,可能导致重复消费。 4. **避免重复投递/消费**: - **生产端**:通过`inner-msg-id`保证消息不重复进入队列。 - **消费端**:利用业务唯一标识`biz-id`判断是否重复消费,例如订单ID、支付ID等。 5. **消息分发机制**: - 轮询分发(循环分发):如果有多个消费者,消息会按顺序分配给每个消费者。 - 路由策略:通过交换器和路由键匹配决定消息流向哪些队列。 6. **消息传输**: - 使用信道:在TCP连接内创建的虚拟通道,允许多个并发连接,减少TCP连接创建的开销。 7. **消息路由**: - 交换器类型:fanout(广播),direct(精确匹配),topic(主题匹配)。 - 路由键匹配:消息根据路由键与队列的绑定关系进行路由。 8. **确保消息不丢失**: - 消息和队列持久化:确保服务器重启后能恢复消息。 - 垃圾收集机制:消费者确认消费后,消息在磁盘上的状态更新为待回收。 9. **RabbitMQ的优点**: - **服务解耦**:降低服务间的直接依赖,增强系统的扩展性。 - **高性能异步通信**:提高系统响应速度,提升用户体验。 - **流量削峰**:缓冲高并发请求,防止系统过载。 10. **集群镜像模式**: - 集群模式下,队列元数据和消息在多个实例间同步,保证高可用性。 - 镜像队列:消息写入时同步到所有实例,消费时自动在所有实例间同步。 通过以上讲解,可以看出RabbitMQ在构建高可用、高并发、异步处理的系统中起着关键作用,其丰富的特性和机制为开发者提供了强大的工具来设计和优化分布式系统。