rabbitmq入门

本文介绍了RabbitMQ的基本结构,包括Broker、Exchange、Queue、Producer和Consumer。详细讲解了消息的发布和接收流程,并阐述了五种工作模式:Work Queues、Publish/Subscribe、Routing、Topics和RPC,以及它们的应用场景。最后提到了开发流程和代码实践链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一. rabbitmq工作原理

下图是RabbitMQ的基本结构:
在这里插入图片描述
组成部分说明如下:
Broker :消息队列服务进程,此进程包括两个部分:Exchange和Queue。
Exchange :消息队列交换机,按一定的规则将消息路由转发到某个队列,对消息进行过虑。
Queue :消息队列,存储消息的队列,消息到达队列并转发给指定的消费方。
Producer :消息生产者,即生产方客户端,生产方客户端将消息发送到MQ。
Consumer :消息消费者,即消费方客户端,接收MQ转发的消息。
connection: mq连接
Channel:会话,每次生产者或消费者与rabbitmq的连通发送消息就是一次会话

消息发布接收流程:
-----发送消息-----
1、生产者和Broker建立TCP连接。
2、生产者和Broker建立通道。
3、生产者通过通道消息发送给Broker,由Exchange将消息进行转发。
4、Exchange将消息转发到指定的Queue(队列)
----接收消息-----
1、消费者和Broker建立TCP连接
2、消费者和Broker建立通道
3、消费者监听指定的Queue(队列)
4、当有消息到达Queue时Broker默认将消息推送给消费者。
5、消费者接收到消息。

二. 常用的几种工作模式
1、Work queues 工作队列模式
2、Publish/Subscribe 发布订阅模式
3、Routing 路由模式
4、Topics 通配符模式
5、Header
6、RPC

三. 开发流程
1、发送端操作流程
1)创建连接
2)创建通道
3)声明队列
4)发送消息
2、接收端
1)创建连接
2)创建通道
3)声明队列
4)监听队列
5)接收消息
6 )ack回复

四. 各种模式介绍
1、Work queues 工作队列模式
在这里插入图片描述
工作队列模式结构:
一个生产者,一个队列,以及一个或多个消费者同时绑定同一队列.
工作方式:
1、一条消息只会被一个消费者接收;
2、rabbit采用轮询的方式将消息是平均发送给消费者的;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
对于 任务过重或任务较多情况使用工作队列可以提高任务处理的速度。

2、Publish/Subscribe 发布订阅模式
在这里插入图片描述

发布订阅模式结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与工作队列相比在生产者和队列之间多了一个交换机,队列与交换机绑定
工作方式:
1、生产者将消息发给交换机exchange,
2、交换机将消息转发到绑定此交换机的每个队列(每个队列都会收到消息)
3、在队列中的消息同样只能被消费一次
适用场景:
发布消息后需要通知全部消费者.

3、Routing 路由模式
在这里插入图片描述
路由模式结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与发布订阅模式的区别:队列与交换机绑定时会指定routingKey
工作方式:
1、一条消息只会被一个消费者接收;
2、生产者发布消息时会指定routingKey,由交换机根据routingkey来转发消息到指定的队列;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
生产者需要根据不同情况区分发送消息到指定消费者

4、Topics 通配符模式
在这里插入图片描述
结构:
一个生产者,一个交换机,一个队列,以及一个或多个消费者同时绑定同一队列.
与路由模式的区别:routingKey支持带通配符.更加灵活,不需要针对每一种情况配置routingKey
工作方式:
1、一条消息只会被一个消费者接收;
2、生产者发布消息时会指定routingKey,由交换机根据routingkey来转发消息到指定的队列;
3、消费者在处理完某条消息后,才会收到下一条消息。
适用场景:
生产者需要根据不同情况区分发送消息到指定消费者

5、Header
header模式与routing不同的地方在于,header模式取消routingkey,使用header中的 key/value(键值对)匹配队列。

6、RPC
在这里插入图片描述
RPC即客户端远程调用服务端的方法 ,使用MQ可以实现RPC的异步调用,基于Direct交换机实现,流程如下:
1、客户端即是生产者就是消费者,向RPC请求队列发送RPC调用消息,同时监听RPC响应队列。
2、服务端监听RPC请求队列的消息,收到消息后执行服务端的方法,得到方法返回的结果
3、服务端将RPC方法 的结果发送到RPC响应队列
4、客户端(RPC调用方)监听RPC响应队列,接收到RPC调用结果。

最后附上代码地址,代码练习部分在 test-rabbitmq工程
https://gitee.com/chenhaotao1992/sc-multipl-project.git

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值