rabbitmq五种工作模式应用场景

本文详细介绍了rabbitmq的五种工作模式:简单模式、轮询、发布订阅、路由和topic主题模式,并通过具体应用场景如短信服务、订单处理、邮件群发等,解释了每种模式的特点和适用情况。在topic主题模式中,通过路由键的范围值匹配,实现了一对多的灵活消息传递。

**

rabbitmq的五种工作模式及应用场景

**
简单模式
在这里插入图片描述

1个生产者将消息交给默认的交换机(AMQP default)
2 交换机获取消息后交给绑定这个生产者的队列(关系是通过队列名称完成)
3 监听当前队列的消费者获取消息,执行消费逻辑
应用场景:短信,聊天
场景:有一个oa系统,用户通过接收手机验证码进行注册,页面上点击获取验证码后,将验证码放到消息队列,然后短信服务从队列中获取到验证码,并发送给用户
工作模式(轮询)
在这里插入图片描述

1 生产者将消息交个交换机
2 交换机交给绑定的队列
3 队列由多个消费者同时监听,只有其中一个能够获取这一条消息,形成了资源的争抢,谁的资源空闲大,争抢到的可能越大;
应用场景:抢红包,大型系统的资源调度
场景:有一个电商平台,有两个订单服务,用户下单的时候,任意一个订单服务消费用户的下单请求生成订单即可。不用两个订单服务同时消费用户的下单请求

3 发布订阅
在这里插入图片描述

1 生产者扔给交换机消息
2 交换机根据自身的类型将会把所有消息复制同步到所有与其绑定的队列
3 每个队列可以有一个消费者,接收消息进行消费逻辑
应用场景:邮件群发,广告
场景:有一个商城,我们新添加一个商品后,可能同时需要去更新缓存和数据库

4 路由模式
在这里插入图片描述

1 生产者还是将消息发送给交换机,消息携带具体的路由key(routingKey)
2 交换机类型direct,将接收到的消息中的routingKey,比对与之绑定的队列的routingKey
3 消费者监听一个队列,获取消息,执行消费逻辑
应用场景:根据生产者的要求发送给特定的一个或者一批队列;错误的通报;
场景:还是一样,有一个商城,新添加了一个商品,实时性不是很高,只需要添加到数据库即可,不用刷新缓存

5 topic主题模式
在这里插入图片描述

1 生产端发送消息,消息携带具体的路由key
2 交换机的类型topic
3 队列绑定交换机不在使用具体的路由key而是一个范围值
.orange. : haha.orange.haha,haha.haha.orange.haha
lazy.# : haha.lazy.haha.haha,layz.alsdhfsh(sh9ou)N0
*表示一个字符串(不能携带特殊符号) 例如 *表示 haha,item,update
#表示任意字符串
场景:还是一样,有一个商城,新添加了一个商品,实时性不是很高,只需要添加到数据库即可,数据库包含了主数据库mysql1和从数据库mysql2的内容,不用刷新缓存

topic主题模式和路由模式区别:
路由模式中的queue绑定携带的是具体的key值,路由细化划分
topic主题模式queue携带的是范围的匹配,某一类的消息获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值