RabbitMQ简介及其核心概念

  • RabbitMQ

    • 是一个开源的AMQP(Advanced Message Queuing Protocol高级消息队列协议)实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.Net、Java、C,用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不错,与Spring AMQP完美整合、API丰富易用
  • 核心概念

    • Broker

      • RabbitMQ的服务端程序,可以认为一个mq节点就是一个broker
    • Producer生产者

      • 创建消息Message,然后发布到RabbitMQ中
    • Consumer消费者

      • 消费队列里面的消息
    • Message消息

      • 生产消费的内容,有消息头和消息体,也包括多个属性配置,比如routingKey路由键
    • Queue队列

      • 是RabbitMQ的内部对象,用于存储信息,消息都只能存储在队列中
    • Channel信道

      • 一条支持多路复用的通道,独立的双向数据流通道,可以发布、订阅、接收消息
      • 信道是建立在真实的TCP连接内的虚拟连接,复用TCP连接的通道
    • Connection连接

      • 是RabbitMQ的socket链接,它封装了socket协议相关部分逻辑,一个连接上可以有多个channel进行通信
    • Exchange交换器

      • 生产者将消息发送到Exchange,交换器将消息路由到一个或者多个队列中,里面有多个类型,后续再一一介绍,队列和交换机是多对多的关系
    • RoutingKey路由键

      • 生产者将消息发给交换器的时候,一般会指定一个RoutingKey,用来指定这个消息的路由规则
      • 最大长度255字节
    • Binding绑定

      • 通过绑定将交换器与队列关联起来,在绑定的时候一般会指定一个绑定键(BindingKey),这样RabbitMQ就知道如何正确的将消息路由到队列了
      • 生产者将消息发送给交换器时,需要一个RoutingKey,当BindingKey和RoutingKey相匹配时,消息会被路由到对应的队列中
    • VirtualHost虚拟主机

      • 用于不同业务模块的逻辑隔离,一个VirtualHost里面可以有若干个Exchange和Queue,同一个VirtualHost里面不能有相同名称的Exchange或Queue
      • 默认是/,可以创建/dev、/test
相关推荐
Wang's Blog8 小时前
RabbitMQ: 消息可靠性保障机制深度解析与工程实践
rabbitmq
Wang's Blog9 小时前
RabbitMQ: 全面安装与运维指南之从基础部署到高级配置
运维·分布式·rabbitmq
小坏讲微服务9 小时前
Spring Boot4.0整合RabbitMQ死信队列详解
java·spring boot·后端·rabbitmq·java-rabbitmq
xrkhy10 小时前
canal1.1.8+mysql8.0+jdk17+rabbitMQ+redis的使用02
前端·redis·rabbitmq
Haooog11 小时前
RabbitMQ面试题(不定时更新)
分布式·后端·面试·rabbitmq·消息中间件
武子康12 小时前
Java-197 消息队列应用场景:缓存预热+限流排队+Redis Lua 扣库存+MQ 削峰填谷
java·redis·缓存·性能优化·消息队列·rabbitmq·java-rabbitmq
驾驭人生13 小时前
RabbitMQ 封装,基于原生 RabbitMQ.Client 实现
分布式·rabbitmq
武子康1 天前
Java-195 RabbitMQ BlockingQueue 手搓“消息中间件”雏形:生产者-消费者模型到企业级 MQ 差在哪
java·分布式·架构·消息队列·rabbitmq·java-rabbitmq·mq
武子康1 天前
Java-196 消息队列选型:RabbitMQ vs RocketMQ vs Kafka
java·分布式·kafka·rabbitmq·rocketmq·java-rocketmq·java-rabbitmq
Wang's Blog2 天前
RabbitMQ: 高并发外卖系统的微服务架构设计与工程实现
分布式·微服务·rabbitmq