Spring-Rabbit消费多个mq中相同的队列

本文介绍了在大规模业务场景下,如何使用Spring-RabbitMQ处理多台服务器上的相同exchange。通过客户端分片策略,生产者将消息分散到不同服务器。消费者需要能消费所有服务器的exchange,但遇到RabbitAdmin的队列维护问题,需要手动注入并指定ConnectionFactory。当队列在不同服务器上不同时,可能需要独立服务或修改RabbitAdmin代码以按服务器区分声明队列。此外,还提到了通过注解添加处理逻辑以及避免Spring Boot自动配置冲突的Bean命名技巧。
摘要由CSDN通过智能技术生成

因为业务规模比较大,采用多台rabbitmq服务器进行处理,在每台rabbitmq建立相同的exchange,采用客户端分片的方式,生产者根据hash分发消息到不同的服务器中。
作为消费者,必须能支持消费全部rabbitmq的相同的exchange。

这里因为4台mq,就在代码中写死数组下标

package cn.jpush.sms.common;

import org.springframework.amqp.core.AcknowledgeMode;
import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.amqp.rabbit.config.SimpleRabbitListenerContainerFactory;
import org.springframework.amqp.rabbit.connection.CachingConnectionFactory;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitAdmin;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.List;

@Configuration
@EnableRabbit
public class RabbitMQConfig {
   

    @Autowired
    private RabbitProperties rabbitProperties;

    @Bean
    public ConnectionFactory connectionFactory() {
        return buildConnectionFactory(0);
    }

    @Bean
    public ConnectionFactory connectionFactory1() {
        return buildConnectionFactory(1);
    }

    @Bean
    public ConnectionFactory connectionFactory2() {
        return buildConnectionFactory(2);
    }

    @Bean
    public ConnectionFactory connectionFactory3() {
        return buildConnectionFactory(3);
    }

    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值