RabbitMQ有5种工作模式

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

RabbitMQ是一套开源(MPL)的消息队列服务软件,是由 LShift 提供的一个 Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能、健壮以及可伸缩性出名的 Erlang 写成。

simple模式

消息产生消息,将消息放入队列

消息的消费者(consumer) 监听 消息队列,如果队列中有消息,就消费掉,消息被拿走后,自动从队列中删除(隐患 消息可能没有被消费者正确处理,已经从队列中消失了,造成消息的丢失,这里可以设置成手动的ack,但如果设置成手动ack,处理完后要及时发送ack消息给队列,否则会造成内存溢出)。

work工作模式

消息产生者将消息放入队列消费者可以有多个,消费者1,消费者2同时监听同一个队列,消息被消费。C1 C2共同争抢当前的消息队列内容,谁先拿到谁负责消费消息(隐患:高并发情况下,默认会产生某一个消息被多个消费者共同使用,可以设置一个开关(syncronize) 保证一条消息只能被一个消费者使用)。

publish/subscribe发布订阅

每个消费者监听自己的队列;

生产者将消息发给broker,由交换机将消息转发到绑定此交换机的每个队列,每个绑定交换机的队列都将接收到消息。

routing路由模式

消息生产者将消息发送给交换机按照路由判断,路由是字符串(info) 当前产生的消息携带路由字符(对象的方法),交换机根据路由的key,只能匹配上路由key对应的消息队列,对应的消费者才能消费消息;

根据业务功能定义路由字符串

从系统的代码逻辑中获取对应的功能字符串,将消息任务扔到对应的队列中。业务场景:error 通知;EXCEPTION;错误通知的功能;传统意义的错误通知;客户通知;利用key路由,可以将程序中的错误封装成消息传入到消息队列中,开发者可以自定义消费者,实时接收错误;

topic 主题模式

  • , # 代表通配符

  • 代表多个单词, # 代表一个单词

消息产生者产生消息,把消息交给交换机

交换机根据key的规则模糊匹配到对应的队列,由队列的监听消费者接收消息消费

RabbitMQ是一个开源的消息中间件,它支持多工作模式。以下是RabbitMQ的几常见工作模式: 1. 简单模式(Simple Mode):简单模式是最基本的工作模式,它包括一个生产者和一个消费者。生产者将消息发送到队列,消费者从队列中接收并处理消息。 2. 工作队列模式(Work Queue Mode):工作队列模式也被称为任务队列模式。它包括一个生产者和多个消费者。生产者将消息发送到队列,多个消费者从队列中接收消息并进行处理。消息在队列中以先进先出的顺序分发给消费者。 3. 发布/订阅模式(Publish/Subscribe Mode):发布/订阅模式用于将消息广播给多个消费者。生产者将消息发送到交换机(Exchange),交换机将消息广播给所有与之绑定的队列,然后消费者从队列中接收并处理消息。 4. 路由模式(Routing Mode):路由模式用于根据消息的路由键(Routing Key)将消息发送到指定的队列。生产者将消息发送到交换机,并指定一个路由键,交换机根据路由键将消息发送到与之匹配的队列,然后消费者从队列中接收并处理消息。 5. 主题模式(Topic Mode):主题模式是一更灵活的路由模式,它根据消息的主题(Topic)将消息发送到指定的队列。生产者将消息发送到交换机,并指定一个主题,交换机根据主题将消息发送到与之匹配的队列,然后消费者从队列中接收并处理消息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值