RabbitMQ 匿名队列详解

在小组代码 Review 时,讨论到了 RabbitMQ 的匿名队列,于是去网上查了下关于匿名队列的内容,并记录下来。

匿名队列是一种特殊的临时队列,在消息传递过程中有着独特的用途,匿名队列也被称为临时队列,它没有固定的名称,其名称由RabbitMQ 服务器自动生成,一般是类似 amq.gen-xxxxxxxxxxxx 的随机字符串。一旦消费者与队列的连接断开,该队列会自动被删除。当只需要临时接收少量消息时,使用匿名队列可以避免手动管理队列的生命周期。

于是,我们就可以了解到匿名队列的使用场景,当接收少量消息的时候,或者定时接收消息,不需要持续性消费的场景下。

还有在微服务架构中,一个服务向另一个服务发送请求,使用匿名队列接收响应消息。例如,服务A向服务B发送一个查询请求,服务A创建一个匿名队列并将队列名称包含在请求消息中发送给服务B,服务B处理请求后将响应消息发送到该匿名队列,服务A从该匿名队列接收响应。

使用匿名队列的好处有:

  • 队列名称由 RabbitMQ 自动生成,不会出现命名冲突。
  • 仅在消费者连接到队列时存在,连接关闭后队列自动删除,无需手动清理资源。
  • 通常是独占队列,即只能由创建它的消费者使用,其他消费者无法访问。

1、在Java中使用 Spring AMQP 创建和使用匿名队列的示例。

java 复制代码
import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.connection.CachingConnectionFactory;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitAdmin;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
@EnableRabbit
public class RabbitMQConfig {

    @Bean
    public ConnectionFactory connectionFactory() {
        CachingConnectionFactory connectionFactory = new CachingConnectionFactory("localhost");
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        return connectionFactory;
    }

    @Bean
    public RabbitAdmin rabbitAdmin(ConnectionFactory connectionFactory) {
        return new RabbitAdmin(connectionFactory);
    }

    @Bean
    public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
        return new RabbitTemplate(connectionFactory);
    }
}

在上述RabbitMQConfig配置类中,创建了与 RabbitMQ 的连接工厂、管理工具和消息模板。

java 复制代码
import org.springframework.amqp.core.AnonymousQueue;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class RabbitMQService {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    public void sendMessage(String exchange, String routingKey, String message) {
        // 创建匿名队列
        AnonymousQueue anonymousQueue = new AnonymousQueue();
        rabbitTemplate.convertAndSend(exchange, routingKey, message);
        // 监听匿名队列接收消息
        receiveMessage(anonymousQueue.getName());
    }

    @RabbitListener(queues = "#{@anonymousQueue.name}")
    public void receiveMessage(String queueName) {
        Object message = rabbitTemplate.receiveAndConvert(queueName);
        if (message != null) {
            System.out.println("Received message: " + message);
        }
    }
}

在上述 RabbitMQServicesendMessage 方法中,使用 AnonymousQueue 类创建了一个匿名队列。通过 rabbitTemplate 发送消息,并使用@RabbitListener 注解监听匿名队列接收消息。

相关推荐
m0_564876841 小时前
Distributed data parallel (DDP)分布式训练
分布式
BYSJMG2 小时前
计算机毕设选题推荐:基于Hadoop的交通事故数据可视化分析系统
大数据·vue.js·hadoop·分布式·后端·信息可视化·课程设计
野犬寒鸦2 小时前
从零起步学习并发编程 || 第三章:JMM(Java内存模型)详解及对比剖析
java·服务器·开发语言·分布式·后端·学习·spring
虫小宝4 小时前
查券返利机器人的异步任务调度:Java XXL-Job+Redis实现海量查券请求的分布式任务分发
java·redis·分布式
yq1982043011565 小时前
构建高可用资源导航平台:基于Django+Scrapy的分布式架构实践
分布式·scrapy·django
你这个代码我看不懂6 小时前
Kafka常见问题解答
分布式·kafka
Tony Bai6 小时前
Git 即数据库:Beads (bd) —— 专为 AI Agent 打造的分布式任务追踪引擎
数据库·人工智能·分布式·git
小邓睡不饱耶6 小时前
Spark Streaming实时微博热文分析系统:架构设计与深度实现
大数据·分布式·spark
北亚数据恢复6 小时前
分布式数据恢复—Ceph+TiDB数据恢复报告
分布式·ceph·数据恢复·tidb·服务器数据恢复·北亚数据恢复·存储数据恢复
Zilliz Planet6 小时前
<span class=“js_title_inner“>Spark做ETL,与Ray/Daft做特征工程的区别在哪里,如何选型?</span>
大数据·数据仓库·分布式·spark·etl