动态管理RabbitMQ队列监听

本文介绍了一种在RabbitMQ中动态监听队列的方法,通过创建和配置监听容器,实现了对队列的实时监听及调整。文章详细展示了如何初始化监听容器、创建监听器并绑定到指定队列,以及如何在队列变动时动态调整监听状态。

需求背景:最近项目要求,动态监听MQ,实现程序新增删除MQ队列的时候,可以动态调整监听。 

废话不说了,贴代码:能力有限,欢迎批判。

import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.TimeoutException;

import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger;
import org.springframework.amqp.AmqpException;
import org.springframework.amqp.core.AcknowledgeMode;
import org.springframework.amqp.core.MessageListener;
import org.springframework.amqp.rabbit.connection.CachingConnectionFactory;
import org.springframework.amqp.rabbit.connection.Connection;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.listener.RabbitListenerEndpointRegistry;
import org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer;

class  
{
    /*initListenerContainer and start listeners
     */
    private void initListenerContainer(){
        logger.info("---------------->>>>>>>>>>> 初始化RabbitMQ监听容器 <<<<<<<<<<<----------------");
        try {
            RabbitListenerEndpointRegistry rabbitListenerEndpointRegistry = DynamicListenerCfg.getRabbitListenerEndpointRegistry();//这里是一个单例,返回一个RabbitListenerEndpointRegistry 实例。
                       
            rabbitListenerEndpointRegistry.stop();

            SimpleMessageListenerContainer container = null;//监听容器
            //connection info
            QueueInfo info = new QueueInfo();
            info.setUserName("userName");
            info.setPassword("helloworld");
            info.setServerIp("192.168.0.110");
            info.setServerPort(5672);
            info.setVirtualHost("/");
            String[] queueNames = null;
                
            queueNames = new String[] {"queueA","queueB"};

            if (queueNames != null && queueNames.length > 0) {
                container = createListenerContainer(MessageListener, info, queueNames);
                Assert.state(!container.isRunning(), String.format("监听容器%s正在运行!", container));
                container.start();
                listenerContainerList.add(container);
            }

            rabbitListenerEndpointRegistry.start();
    
        } catch (Exception e) {
            e.getSuppressed();
        }
        
    }

    //create container by queueName and lisenerInstance
    public SimpleMessageListenerContainer createListenerContainer(MessageListener listenerInstant,QueueInfo info, String ...queueNames) {
        SimpleMessageListenerContainer container = null;
        try {
            ConnectionFactory factory = connectionFactory(info.getServerPort(),info.getUserName(),info.getPassword(),info.getServerIp(),info.getVirtualHost());
            container = new SimpleMessageListenerContainer(factory);
            container.addQueueNames(queueNames);
            container.setMessageListener(listenerInstant);//配置自定义的监听类
            container.setAutoStartup(isAutoStartUp);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return container;
        
    }

    //create queue and bind listener
	public boolean addListenerQueue(QueueInfo info) throws AmqpException, IOException {
		boolean rst = false;
		//create queue
		
		Connection connection = null;
		try {
			connection = connectionFactory(info.getServerPort(),info.getUserName(),info.getPassword(),info.getServerIp(),info.getVirtualHost()).createConnection();
            //如果删除队列,这里改成调用queueDelete方法即可(先判断下messageCount是否还有消息未处理)
			connection.createChannel(false).queueDeclare(info.getQueueName(), false, false, true, null);

			//监听队列	
		        listenerContainerList.forEach(a->a.stop());
            //删除的时候这里改为调用removeQueueNames即可.
			listenerContainerList.forEach(a->a.addQueueNames(info.getQueueName()));
			listenerContainerList.forEach(a->a.start());

			rst = true;
		} catch (Exception e) {
			rst = false;
			e.printStackTrace();
		} finally {
			if (connection != null) {
				connection.close();
			}
		}
		return rst;
	}
}

 

RabbitMQ队列监听器是用于在RabbitMQ监听队列的组件。它可以动态地创建队列,并将队列放入监听器中,以便实时接收并处理队列中的消息。 在Java中,可以使用SimpleMessageListenerContainer类来创建和管理RabbitMQ队列监听器。这个类负责监听队列的添加、移除等操作。它是RabbitMQ中专门用于监听队列的组件。 要使用SimpleMessageListenerContainer类创建队列监听器,首先需要使用@Autowired和@Qualifier注解将RabbitAdmin和SimpleMessageListenerContainer类注入到代码中。然后,可以使用RabbitAdmin的方法来创建队列并将其绑定到交换机上。最后,使用SimpleMessageListenerContainer的方法将队列添加到监听器中并启动监听器。这样,就可以实现对队列中消息的监听和处理了。 另外,在一些配置类中,例如RabbitBootstrapConfiguration类中,可以定义RabbitListenerEndpointRegistry bean来进行监听容器的注册操作。这个bean负责管理和注册RabbitMQ监听器的相关操作。通过定义这个bean,可以更方便地管理和配置RabbitMQ队列监听器。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [springBoot整合rabbitMQ动态创建队列动态监听。(三)](https://blog.youkuaiyun.com/web15085181368/article/details/124077397)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [springboot-rabbitmq 实现动态配置监听容器](https://blog.youkuaiyun.com/m0_46978151/article/details/124875003)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值