目录
官方网站:RabbitMQ
介绍
具体来说,Work Queues 中包含一个或多个生产者(Producer)和多个消费者(Consumer)。生产者将任务提交到共享的 Queue(任务队列),然后由多个消费者竞争式地获取任务并处理。当一个消费者获取到了任务并开始处理时,该任务就从 Queue 中移除了,其他消费者就不能再处理这个任务。这样,每个任务只会被一个消费者处理,而且不同的消费者可以处理不同的任务,从而实现了任务的并行处理和负载均衡。一个队列可以被多个消费者共享,当有多个消费者同时监听同一个队列时,将会采取轮询方式将消息分发给各个消费者。
使用 「Bean 」 配置Work Queues
/**
* 工作队列模式
*
* @author xiangtianlei
* @date 2023/06/08
*/
@Configuration
public class SimpleQueueConfig {
Logger logger = LoggerFactory.getLogger(SimpleQueueConfig.class);
@Bean(name = "simpleQueue")
public Queue queue() {
return new Queue("simple_queue", true, false, true);
}
@RabbitListener(queues = "simple_queue")
public void readMessage(String msg) {
logger.info("one接收到的消息为:{}", msg);
}
@RabbitListener(queues = "simple_queue")
public void readMessageTwo(String msg) {
logger.info("two接收到的消息为:{}", msg);
}
}
下面是
new Queue()
方法的各个参数的详解:
name
:要创建的队列的名称。该参数为必选参数,不能为空或 null 值。
durable
:是否将队列设置为持久化。持久化队列会将队列信息存储到磁盘上,即使 RabbitMQ 服务器停止运行或重启后也能够自动恢复队列。默认值为 false,表示不持久化。
exclusive
:是否将队列设置成排他性质的队列。排他队列只能被首次声明它的连接使用,并在连接关闭时自动删除。默认值为 false,表示不是排他队列。
autoDelete
:是否将队列设置为自动删除。即在最后一个消费者断开连接后,自动删除该队列。默认值为 false,表示不自动删除。
arguments
:用于设置其他参数的可选参数,可以传入 null 或 Map<String, Object> 类型的参数列表。常见的参数有:
x-message-ttl
:队列中消息的过期时间。单位为毫秒(ms)。例如,设置 x-message-ttl 为 10000 表示队列中的消息十秒钟后过期。
x-max-length
:队列允许存放最大消息数。例如,设置 x-max-length 为 100 表示队列中最多能存放 100 条消息。
x-max-length-bytes
:队列允许存放的最大字节数。例如,设置 x-max-length-bytes 为 1024 表示队列中最多能存放 1KB 的消息数据。
x-dead-letter-exchange
和x-dead-letter-routing-key
:用于设置死信队列,即当队列中的消息被拒绝或超时时将消息发送到指定的队列和路由键。
模拟生产者发送消息①
@SpringBootTest(classes = MqApplication.class)
@RunWith(SpringRunner.class)
public class ProducerSimpleTest {
@Resource
RabbitTemplate rabbitTemplate;
@Test
public void sendDelayMessageByDirect() {
for (int i = 0; i < 10; i++) {
rabbitTemplate.convertAndSend("simple_queue", "简单队列!!!!!");
}
}
}