问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

RabbitMQ实战:核心组件及其工作原理详解

创作时间:
作者:
@小白创作中心

RabbitMQ实战:核心组件及其工作原理详解

引用
CSDN
1.
https://blog.csdn.net/yprufeng/article/details/136595848

RabbitMQ是一个开源的消息代理软件,实现了高级消息队列协议(AMQP)标准,提供可靠的消息传递机制。它支持多种编程语言,并提供了丰富的功能和插件,使得开发者能够更轻松地构建分布式系统。本文将介绍RabbitMQ的核心组件及其工作原理,帮助读者更好地使用RabbitMQ作为消息中间件实现具体的业务场景。

使用docker安装一个rabbitmq消息中间键

# latest RabbitMQ 3.13
docker run -it --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3.13-management  

rabbitmq的核心组件

①Broker(服务器)

  • rabbitmq的服务器,用于存储消息的服务器。

②Exchange(交换机)

  • 用于接收来自生产者的消息,并将这些消息路由到一个或多个与之绑定的队列。

③Queue(队列)

  • 用于存储消息的组件,为防止消息丢失,可持久化存储。

④Binding(绑定关系)

  • 定义了 Exchange 和 Queue 之间的关系,它指定了消息应该如何从 Exchange 路由到相应的队列。

⑤Connection(通信连接)

  • 客户端和RabbitMQ之间的TCP连接,用于消息的发送(生产者)或者消息的接收(发布者)。

⑥Channel(信道)

  • 在连接中创建的虚拟连接,用于执行大部分的 AMQP操作。

⑦Virtual host

  • 一个逻辑概念,它让 RabbitMQ可以在一台物理机上支持多个独立的消息代理实例。

rabbitmq的工作原理

发布消息:生产者producer通过Connection连接与broker服务器建立一个Channel信道,将消息发送给交换机Exchange,交换机通过路由键router-key将不同主题的消息通过路由键转发给消息队列Queue,消息被存储在Queue队列中,默认是内存存储,服务器重启消息会丢失,生产使用一般会开启持久化存储。

消费消息:消费者consumer通过Connection连接与broker服务器建立一个Channel信道,主动拉取或者通过服务器推送来消费消息。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号