「RabbitMQ」使用Work工作队列实现消息的投递

目录

介绍

使用 「Bean」配置Work Queues

模拟生产者发送消息①


官方网站: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() 方法的各个参数的详解:

  1. name要创建的队列的名称。该参数为必选参数,不能为空或 null 值。

  2. durable是否将队列设置为持久化。持久化队列会将队列信息存储到磁盘上,即使 RabbitMQ 服务器停止运行或重启后也能够自动恢复队列。默认值为 false,表示不持久化。

  3. exclusive是否将队列设置成排他性质的队列。排他队列只能被首次声明它的连接使用,并在连接关闭时自动删除。默认值为 false,表示不是排他队列。

  4. autoDelete是否将队列设置为自动删除。即在最后一个消费者断开连接后,自动删除该队列。默认值为 false,表示不自动删除。

  5. 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-exchangex-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", "简单队列!!!!!");
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术路上的探险家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值