【面试】rabbitmq的主要组件有哪些?

目录

          • [1. Producer(生产者)](#1. Producer(生产者))
          • [2. Broker(消息代理)](#2. Broker(消息代理))
          • [3. Exchange(交换机)](#3. Exchange(交换机))
          • [4. Queue(队列)](#4. Queue(队列))
          • [5. Consumer(消费者)](#5. Consumer(消费者))
          • [6. Binding(绑定)](#6. Binding(绑定))
          • [7. Channel(信道)](#7. Channel(信道))
          • [8. Virtual Host(虚拟主机)](#8. Virtual Host(虚拟主机))
          • [8. Plugin(插件)](#8. Plugin(插件))
1. Producer(生产者)
  • 1.负责生产消息并将其发送到RabbitMQ服务器。
  • 2.生产者将消息发送到指定的交换机(Exchange)。
2. Broker(消息代理)
  • 1.RabbitMQ服务器本身,负责接收、存储和转发消息。
  • 2.Broker内部维护着交换机、队列、绑定关系等组件。
3. Exchange(交换机)
  • 1.负责接收生产者发送的消息,并根据路由规则将消息分发到一个或多个队列。
  • 2.交换机有多种类型,如Direct、Fanout、Topic、Headers等。
4. Queue(队列)
  • 1.用于存储消息,等待消费者来拉取并处理。
  • 2.队列具有持久化、排他性、自动删除等属性。
5. Consumer(消费者)
  • 1.负责接收并处理从RabbitMQ服务器中取出的消息。
  • 2.消费者从队列(Queue)中拉取消息进行消费。
6. Binding(绑定)
  • 1.定义了交换机和队列之间的路由规则。
  • 2.通过绑定,交换机可以知道将消息发送到哪些队列。
7. Channel(信道)
  • 1.在客户端和Broker之间建立的一条TCP连接上的虚拟连接。
  • 2.信道是AMQP协议中用于发送和接收命令的轻量级连接。
  • 3.通过信道,客户端可以与Broker进行交互,如发送消息、接收消息、声明交换机和队列等。
8. Virtual Host(虚拟主机)
  • 1.提供了逻辑上的隔离,每个虚拟主机都有自己独立的交换机、队列、绑定和权限机制。
  • 2.虚拟主机类似于数据库中的数据库实例,用于隔离不同的应用或环境。
8. Plugin(插件)
  • 1.RabbitMQ支持通过插件扩展其功能,如管理界面、消息追踪、延迟队列等。
  • 2.插件可以动态加载到RabbitMQ服务器中,以提供额外的功能或优化性能。
相关推荐
2501_941143322 小时前
微服务架构与服务网格在高并发互联网系统中的优化与工程实践经验分享
rabbitmq
2501_941871453 小时前
C++结合Redis与WebSocket构建高并发实时在线游戏服务设计与实战分享:成都多人竞技游戏架构优化经验
rabbitmq
2501_941870567 小时前
多语言微服务架构下的分布式事务管理与最终一致性实践
rabbitmq
2501_941878747 小时前
智能推荐系统与多语言微服务实现:Python、Java、C++与Go全栈开发实战
rabbitmq
han_8 小时前
前端高频面试题之CSS篇(一)
前端·css·面试
덕화8 小时前
【面试宝典】线上问题逆向分析1
面试·职场和发展
美团程序员8 小时前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
2501_941809149 小时前
Python在高并发互联网系统开发中的架构设计与性能优化全流程实践分享
rabbitmq
2501_9411458510 小时前
基于 Node.js 与 NestJS 构建高并发微服务与实时 API 系统实践分享
rabbitmq
2501_9411471110 小时前
Python大数据处理实战:异步IO与协程高效数据解析代码解析
rabbitmq