Springboot集成RabbitMQ【Direct Exchange】

本文只针对路由直连模式(Direct Exchange)的使用。


一、生产者端的队列/交换器配置:
这里只有生产者客户端需要配置,消费者端可无需配置。

@Configuration
public class DirectRabbitConfig {

    /**
     * 创建队列
     * @return
     */
    @Bean
    public Queue CustomDirectQueue() {
    	// 这里Queue对象有四个常用参数
        // name:消息队列命名。
        // durable:默认为false,是否持久化。持久化队列会被存储在磁盘上,当消息代理重启时仍然存在;否则当前连接有效。
        // exclusive:默认为false,只能被当前创建的连接使用,当连接关闭后队列即被删除,优先级高于durable。
        // autoDelete:默认为false,是否自动删除,当没有生产者或者消费者使用此队列,则队列自动删除。
        return new Queue("CustomDirectQueue", true);
    }

    /**
     * 创建 Direct交换器
     * @return
     */
    @Bean
    public DirectExchange CustomDirectExchange() {
        return new DirectExchange("CustomDirectExchange", true, false);
    }

    /**
     * 将交换器与队列绑定,设定匹配键
     * @return
     */
    @Bean
    public Binding binding() {
        return BindingBuilder.bind(CustomDirectQueue()).to(CustomDirectExchange()).with("custom.direct.routing");
    }

}

二、消费者端的监听消费:

  • 注解@RabbitListener可标注在方法上,表示当监听到指定的队列中有消息时会由该方法进行接收处理。
  • 注解@RabbitListener也可标注在类上,但需要搭配注解@RabbitHandler使用,表示当监听到指定的队列中有消息时,就会交给对应的@RabbitHandler进行接收处理。
  • 注解@RabbitHandler可以有多个,但参数类型不能一样。交由哪个方法处理则根据MessageConverter转换后的参数类型来决定。
@Component
@RabbitListener(queues = "CustomDirectQueue")
public class DirectConsumer {

    @RabbitHandler
    public void process(Map message) {
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("[consumer-1]从队列 [CustomDirectQueue] 收到消息:" + message.toString());
    }

    @RabbitListener(queues = "CustomDirectQueue")
    public void process2(Map message) {
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("[consumer-2]从队列 [CustomDirectQueue] 收到消息:" + message.toString());
    }

}


三、发送消息到队列:
下面只是调试样例,不涉及业务。

@RequestMapping("/producer")
@RestController
public class ProducerController {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    @GetMapping("send")
    public String sendDirectMessage() {
        int i = 0;
        while(i < 100000) {
            HashMap<String, Object> map = new HashMap();
            map.put("message_id", UUID.randomUUID());
            map.put("message_msg", "这是一条消息数据");
            map.put("message_num", ++i);
            map.put("message_created_time", new Date());
            rabbitTemplate.convertAndSend("CustomDirectExchange", "custom.direct.routing", map);
        }
        return "发送成功";
    }

}

使用Postman进行模拟消息发送,最终可以看到两个消费者同时在处理这个队列的消息,默认使用的是轮询方式将消息分发给两个消费者。若某一个消费者处理的比较慢,依旧会导致应分发到该消费者的消息存在挤压情况。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值