如何在ActiveMQ中禁用InactivityMonitor日志?

时间:2017-08-17 16:36:31

标签: java activemq message-queue spring-jms

我已在我的应用程序中实现了ActiveMQ消息代理,但每当我在控制台日志中连接到ActiveMQ服务器时,我总是看到以下消息:

10:28:05.282 [ActiveMQ InactivityMonitor WriteCheckTimer] DEBUG o.a.a.t.AbstractInactivityMonitor - WriteChecker: 10000ms elapsed since last write check.
10:28:05.282 [ActiveMQ InactivityMonitor Worker] DEBUG o.a.a.t.AbstractInactivityMonitor - Running WriteCheck[tcp://10.211.127.203:61616]

看起来它继续轮询它似乎的侦听器队列。我希望我的监听器处于活动状态,这样每当消息进入队列时,应用程序就可以处理它。同时,我不希望此消息堆积我的日志文件。

我的消息配置:

@Configuration
@EnableJms
@ImportResource("classpath*:beans.xml")
public class MessagingConfiguration {   

    @Autowired
    MongoCredentialEncryptor encryptor;  

    @Value("${activemq.broker.url}")
    private String BROKER_URL = "tcp://localhost:61616";

    @Value("${activemq.request.queue}")
    private String REQUEST_QUEUE = "test.request";

    @Value("${activemq.response.queue}")
    private String RESPONSE_QUEUE = "test.response";

    @Value("${activemq.borker.username}")
    private String BROKER_USERNAME = "admin";

    @Value("${activemq.borker.password}")
    private String BROKER_PASSWORD = "admin";

    @Autowired
    ListenerClass messageListener;

    @Autowired
    JmsExceptionListener jmsExceptionListener;

    @Bean
    public ActiveMQConnectionFactory connectionFactory() {
        ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
        connectionFactory.setBrokerURL(BROKER_URL);
        connectionFactory.setUserName(BROKER_USERNAME);
        //connectionFactory.setPassword(BROKER_PASSWORD);
        connectionFactory.setPassword(encryptor.decrypt(BROKER_PASSWORD));
        connectionFactory.setTrustAllPackages(true);
        connectionFactory.setRedeliveryPolicy(redeliveryPolicy());
        return connectionFactory;
    }

    @Bean
    public RedeliveryPolicy redeliveryPolicy() {
        RedeliveryPolicy redeliveryPolicy = new RedeliveryPolicy();
        redeliveryPolicy.setBackOffMultiplier(3); // Wait 5 seconds first re-delivery, then 15, 45 seconds
        redeliveryPolicy.setInitialRedeliveryDelay(5000);
        redeliveryPolicy.setMaximumRedeliveries(3);
        redeliveryPolicy.setUseExponentialBackOff(true);
        return redeliveryPolicy;
    }

    @Bean
    public ConnectionFactory cachingConnectionFactory() {
        CachingConnectionFactory connectionFactory = new CachingConnectionFactory();
        connectionFactory.setTargetConnectionFactory(connectionFactory());
        connectionFactory.setExceptionListener(jmsExceptionListener);
        connectionFactory.setSessionCacheSize(100);
        connectionFactory.setCacheConsumers(false);
        connectionFactory.setCacheProducers(false);
        return connectionFactory;
    }

    @Bean
    public JmsTemplate jmsTemplate() {
        JmsTemplate template = new JmsTemplate();
        template.setConnectionFactory(connectionFactory());
        template.setDefaultDestinationName(REQUEST_QUEUE);
        template.setSessionAcknowledgeModeName("CLIENT_ACKNOWLEDGE");
        template.setMessageConverter(converter());
        return template;
    }

    @Bean
    public DefaultMessageListenerContainer jmsListenerContainer() {
        DefaultMessageListenerContainer factory = new DefaultMessageListenerContainer();
        factory.setConnectionFactory(connectionFactory());
        factory.setConcurrency("1-1");
        factory.setDestinationName(RESPONSE_QUEUE);
        factory.setMessageListener(messageListener);
        factory.setExceptionListener(jmsExceptionListener);
        return factory;
    }

    @Bean
    MessageConverter converter() {
        MappingJackson2MessageConverter converter = new MappingJackson2MessageConverter();
        converter.setTargetType(MessageType.TEXT);
        converter.setTypeIdPropertyName("_type");
        return converter;
    }

}

解决方案: 我通过关注此链接ActiveMQ InactivityMonitor来禁用InactivityMonitor,从而找到了解决问题的方法。我测试了它的连接仍然存在并且它不会继续轮询队列。但我想知道禁用InactivityMonitor是否有任何挫折?有没有更好的解决方案来解决这个问题。

activemq.broker.url=failover:tcp://localhost:61616?wireFormat.maxInactivityDuration=0

3 个答案:

答案 0 :(得分:0)

修复很简单,将日志记录设置更改为不在调试级别写入,或者将一个记录器过滤到不在调试级别。日志会让您及时了解客户端是否成功ping远程代理以确保连接处于活动状态。如果您禁用监控,那么您可能会错过连接丢弃事件,例如半封闭套接字等。

在制作中,您真的不想关闭连接检查功能,导致您的代码错过了无法接收任何内容的事实

答案 1 :(得分:0)

谢谢蒂姆的推荐。我将此日志记录移至WARN级别。

 <logger name="org.apache.activemq.transport" level="WARN"/>

答案 2 :(得分:0)

如果打印此日志,则没有任何危害,InactivityMonitor仅检查代理与客户端之间的连接是否处于活动状态。

如果发现在给定时间内该连接处于非活动状态,则InactivityMonitor将关闭客户端与代理之间的连接。

我们可以通过在activemq.xml文件的transportConnectors部分的tcp URL中指定InactivityMonitor来设置wireFormat.maxInactivityDuration="<time in ms>"的超时时间。

有关详细信息,请访问:InactivityMonitor