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