如何保持 SimpleMessageListenerContainer 处于活动状态,直到使用此容器的所有线程关闭

问题描述

服务器停止后获取如下日志

2020-04-01 01:34:44.353 INFO ABC --- [ Thread-2] o.s.a.r.l.SimpleMessageListenerContainer :关闭被忽略 - 容器已经不活动

SimpleMessageListenerContainer 代码

@Bean
    public RabbitListenerContainerFactory<SimpleMessageListenerContainer> rabbitListenerContainerFactory(ConnectionFactory connectionFactory) {
        SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
        factory.setConnectionFactory(connectionFactory);
        factory.setAckNowledgeMode(AckNowledgeMode.NONE);
        factory.setAfterReceivePostProcessors(m -> {
            m.getMessageProperties().setContentType("text/plain");
            return m;
        });
        return factory;
    }

消费者类如下

@Component
public class ConsumerOne {

    @RabbitListener(queues = "queue_one"},containerFactory = "rabbitListenerContainerFactory")
    public void onMessage(String message) {
        try {
            LOGGER.info(message);
        } catch (Exception e) {
            LOGGER.error("EXCEPTION ",message,e);
        }
    }
}

我有多个用于多个队列的消费者类。提前致谢

解决方法

我刚刚确定这是一条虚假消息;容器本身正在发出错误的日志。

您可以放心地忽略它。

https://github.com/spring-projects/spring-amqp/issues/1317

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...