RabbitMQ有5中工作模式:简单模式、工作队列模式、发布/订阅模式、路由模式和主题模式
简单模式是最基本的工作模式,也是最简单的模式。在简单模式中,生产者将消息发送到一个队列中,然后消费者从该队列中接收并处理消息。这种模式下,一个生产者可以发送多个消息,但只有一个消费者能够接收和处理这些消息。简单模式适用于单个生产者和单个消费者的场景。
具体实现
1. 导入依赖、在依赖文件配置rabbitmq(消费者和生产者程序都要实现)
- <dependency>
- <groupId>org.springframework.bootgroupId>
- <artifactId>spring-boot-starter-amqpartifactId>
- dependency>
- spring:
- rabbitmq:
- host: 192.168.10.100 # 自己的虚拟机IP
- port: 5672 # 端口
- virtual-host: /root # 虚拟主机
- username: root # 用户名
- password: root # 密码
2. 创建消费者(一个程序)
- @Component
- public class SimpleModeProducer {
-
- @Autowired
- private RabbitTemplate rabbitTemplate;//注入中央类
-
- public void sendMessage(String queueName, String message) {
- rabbitTemplate.convertAndSend(queueName, message);
- System.out.println("发送的消息: " + message);
- }
- }
3.创建消费者(另一个程序)
- @Component
- public class SimpleModeConsumer {
-
- @RabbitListener(queues = "simple.queue")//监听队列,自动检测
- public void receiveMessage(String message) {
- System.out.println("接收到的消息: " + message);
- }
- }
4. 测试(在生产者程序)
- @SpringBootTest
- public class SimpleModeTest {
-
- @Autowired
- private SimpleModeProducer producer;
-
- @Test
- public void testSimpleMode() {
- producer.sendMessage("simple.queue","hello, rabbitmq!");
- }
- }
工作队列模式也被称为任务队列模式,在工作队列模式中,生产者将消息发送到一个队列中,多个消费者同时监听该队列,并竞争地接收消息进行处理。每个消息只能被一个消费者接收,确保消息的唯一性。工作队列模式可以实现任务的并行处理,提高系统的处理能力。
发布/订阅模式将消息发送到交换机(exchange),然后交换机将消息广播给所有绑定的队列。每个队列都有自己的消费者,从而实现了消息的广播。在发布/订阅模式中,生产者将消息发送到交换机,而不是直接发送到队列。交换机根据绑定的队列将消息进行广播。这种模式适用于需要将消息广播给多个消费者的场景。
路由模式在发布/订阅模式的基础上增加了路由键(routing key)的概念。生产者将消息发送到交换机,并指定一个路由键。交换机根据路由键的匹配规则将消息发送到相应的队列。消费者可以选择订阅特定的路由键,只接收符合条件的消息。这种模式适用于需要根据消息的属性或条件进行消息路由的场景。
主题模式是路由模式的扩展,它使用通配符来匹配路由键。生产者将消息发送到交换机,并指定一个主题(topic)。交换机根据主题的模式匹配将消息发送到符合条件的队列。主题模式可以实现更灵活的消息路由,可以根据不同的主题将消息发送给不同的队列。这种模式适用于需要根据消息的主题进行灵活路由的场景。