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 注解监听匿名队列接收消息。

相关推荐
KmSH8umpK2 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
KmSH8umpK4 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
_F_y9 小时前
仿RabbitMQ实现消息队列-服务端核心模块实现(4)
分布式·rabbitmq
Albert Edison12 小时前
【RabbitMQ】发布确认模式(使用案例)
分布式·rabbitmq·ruby
EXnf1SbYK14 小时前
Redis分布式锁进阶第十二篇:全系列终极兜底复盘 + 锁架构巡检落地 + 线上零事故收尾方案
redis·分布式·架构
EXnf1SbYK14 小时前
Redis分布式锁进阶第八篇:锁超时乱序深度踩坑 + 看门狗失效真实溯源 + 业务长耗时标准化兜底方案
数据库·redis·分布式
EXnf1SbYK14 小时前
Redis分布式锁进阶第十一篇
数据库·redis·分布式
biyezuopinvip15 小时前
分布式风电场低电压穿越故障建模与仿真
分布式·matlab·毕业设计·毕业论文·分布式风电场·低电压穿越故障·建模与仿真
苍煜15 小时前
SpringBoot单体应用到分布式下的数据库锁、事务、Redis事务、分布式锁、分布式事务协调
数据库·spring boot·分布式
fengxin_rou16 小时前
黑马点评项目万字总结:从redis基础到实战应用详解
java·开发语言·分布式·后端·黑马点评