Apache MQ Artemis-MQTT保留消息对于连接到群集中其他节点的客户端不可用 [英] Apache MQ Artemis - MQTT retained message not available for a client that connects to other node in cluster

查看:21
本文介绍了Apache MQ Artemis-MQTT保留消息对于连接到群集中其他节点的客户端不可用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有4个ActiveMQ Artemis 2.10.1实例在群集中运行。客户端(A)连接到其中一个节点并发布MQTT消息,QoS=0且Retention=true。当新的MQTT客户端(B)连接到集群中的另一个节点并订阅该主题时,之前发送的消息为未收到。当客户端A发布下一条消息时,客户端B将收到该消息。

客户端B连接到群集中的另一个节点时,A发送的保留消息未被客户端B接收,这是Artemis中的错误吗?或者我遗漏了什么?

如果我将客户端A和客户端B连接到群集中的同一节点,则客户端B在连接并订阅该主题后会收到消息。

broker.xml-我使用poc.#进行测试:

<configuration xmlns="urn:activemq"
               xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
               xmlns:xi="http://www.w3.org/2001/XInclude"
               xsi:schemaLocation="urn:activemq /schema/artemis-configuration.xsd">

    <core xmlns="urn:activemq:core" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:activemq:core ">

        <name>Broker 01</name> <!-- changed on every node -->

        <persistence-enabled>true</persistence-enabled>
        <journal-type>NIO</journal-type>
        <paging-directory>data/paging</paging-directory>
        <bindings-directory>data/bindings</bindings-directory>
        <journal-directory>data/journal</journal-directory>
        <large-messages-directory>data/large-messages</large-messages-directory>
        <journal-datasync>true</journal-datasync>
        <journal-min-files>2</journal-min-files>
        <journal-pool-files>10</journal-pool-files>
        <journal-device-block-size>4096</journal-device-block-size>
        <journal-file-size>10M</journal-file-size>

        <journal-buffer-timeout>1328000</journal-buffer-timeout>

        <journal-max-io>1</journal-max-io>
        <disk-scan-period>5000</disk-scan-period>
        <max-disk-usage>90</max-disk-usage>
        <critical-analyzer>true</critical-analyzer>
        <critical-analyzer-timeout>120000</critical-analyzer-timeout>
        <critical-analyzer-check-period>60000</critical-analyzer-check-period>
        <critical-analyzer-policy>HALT</critical-analyzer-policy>

        <acceptors>
            <acceptor name="artemis">tcp://0.0.0.0:61616</acceptor>
            <acceptor name="mqtt">tcp://0.0.0.0:1883?protocols=MQTT</acceptor>
        </acceptors>

        <connectors>
            <connector name="netty-connector">tcp://10.0.0.2:61616</connector>  <!-- changed on every node -->
        </connectors>

        <broadcast-groups>  
            <broadcast-group name="my-broadcast-group">  
                <group-address>231.7.7.7</group-address>  
                <group-port>9876</group-port>  
                <broadcast-period>2000</broadcast-period>  
                <connector-ref>netty-connector</connector-ref>  
            </broadcast-group>  
        </broadcast-groups>
        <discovery-groups>  
            <discovery-group name="my-discovery-group">  
                <group-address>231.7.7.7</group-address>  
                <group-port>9876</group-port>  
                <refresh-timeout>10000</refresh-timeout>  
            </discovery-group>  
        </discovery-groups>

        <cluster-connections>
             <cluster-connection name="artemis-cluster">
                <address></address>
                <connector-ref>netty-connector</connector-ref>
                <retry-interval>1000</retry-interval>
                <use-duplicate-detection>true</use-duplicate-detection>
                <message-load-balancing>ON_DEMAND</message-load-balancing>
                <max-hops>1</max-hops>
                <discovery-group-ref discovery-group-name="my-discovery-group"/> 
             </cluster-connection>
        </cluster-connections>

        <security-settings>
            <security-setting match="#">
                <permission type="createNonDurableQueue" roles="amq"/>
                <permission type="deleteNonDurableQueue" roles="amq"/>
                <permission type="createDurableQueue" roles="amq"/>
                <permission type="deleteDurableQueue" roles="amq"/>
                <permission type="createAddress" roles="amq"/>
                <permission type="deleteAddress" roles="amq"/>
                <permission type="consume" roles="amq"/>
                <permission type="browse" roles="amq"/>
                <permission type="send" roles="amq"/>
                <!-- we need this otherwise ./artemis data imp wouldn't work -->
                <permission type="manage" roles="amq"/>
            </security-setting>

            <!-- Security setting for testing. -->
            <security-setting match="poc.#">
                <permission type="createNonDurableQueue" roles="read-write"/>
                <permission type="deleteNonDurableQueue" roles="read-write"/>
                <permission type="createDurableQueue" roles="read-write"/>
                <permission type="deleteDurableQueue" roles="read-write"/>
                <permission type="createAddress" roles="read-write"/>
                <permission type="deleteAddress" roles="write"/>
                <permission type="consume" roles="read-write"/>
                <permission type="browse" roles="read-write"/>
                <permission type="send" roles="write"/>
            </security-setting>
        </security-settings>

        <address-settings>
            <address-setting match="activemq.management#">
                <dead-letter-address>DLQ</dead-letter-address>
                <expiry-address>ExpiryQueue</expiry-address>
                <redelivery-delay>0</redelivery-delay>
                <max-size-bytes>-1</max-size-bytes>
                <message-counter-history-day-limit>10</message-counter-history-day-limit>
                <address-full-policy>PAGE</address-full-policy>
                <auto-create-queues>true</auto-create-queues>
                <auto-create-addresses>true</auto-create-addresses>
                <auto-create-jms-queues>true</auto-create-jms-queues>
                <auto-create-jms-topics>true</auto-create-jms-topics>
            </address-setting>
            <address-setting match="#">
                <dead-letter-address>DLQ</dead-letter-address>
                <expiry-address>ExpiryQueue</expiry-address>
                <redelivery-delay>0</redelivery-delay>
                <max-size-bytes>-1</max-size-bytes>
                <message-counter-history-day-limit>10</message-counter-history-day-limit>
                <address-full-policy>PAGE</address-full-policy>
                <auto-create-queues>true</auto-create-queues>
                <auto-create-addresses>true</auto-create-addresses>
                <auto-create-jms-queues>true</auto-create-jms-queues>
                <auto-create-jms-topics>true</auto-create-jms-topics>
            </address-setting>

            <!-- Address setting for testing -->
            <address-setting match="poc.#">
                <dead-letter-address>DLQ</dead-letter-address>
                <expiry-address>ExpiryQueue</expiry-address>
                <redelivery-delay>0</redelivery-delay>
                <max-size-bytes>-1</max-size-bytes>
                <message-counter-history-day-limit>10</message-counter-history-day-limit>
                <address-full-policy>PAGE</address-full-policy>
                <auto-create-queues>true</auto-create-queues>
                <auto-delete-queues>true</auto-delete-queues>
                <auto-create-addresses>true</auto-create-addresses>
                <auto-delete-addresses>true</auto-delete-addresses>
                <default-address-routing-type>MULTICAST</default-address-routing-type>
            </address-setting>
        </address-settings>

        <addresses>
            <address name="DLQ">
                <anycast>
                    <queue name="DLQ" />
                </anycast>
            </address>
            <address name="ExpiryQueue">
                <anycast>
                    <queue name="ExpiryQueue" />
                </anycast>
            </address>
        </addresses>
    </core>
</configuration>

推荐答案

您需要为您关心的地址设置这个<address-setting>

<redistribution-delay>0</redistribution-delay>

有关详细信息,请参阅ActiveMQ Artemis文档的"Message Redistribution"部分。

这篇关于Apache MQ Artemis-MQTT保留消息对于连接到群集中其他节点的客户端不可用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆