JBoss EAP7.1在群集模式下集成的ActiveMQ Artemis消息重新分发不起作用
在下列第29项之后,重新分配测试不起作用 测试用例:1个jboss主机和2个jboss从机。我在artemis中创建了“respostaCsu”队列,并在其上发布了一条消息。消息是从1号机发来的。这没有关联其correlationId的侦听器,因此没有从队列中删除消息。根据RedHat(再分配延迟=0,消息负载平衡类型=按需)文档,消息应转发到下一台群集计算机(从机-2)。但是,该消息未重定向,并保留在从属1中 有什么建议吗 JBoss EAP 7.1 master domain.xml文件:JBoss EAP7.1在群集模式下集成的ActiveMQ Artemis消息重新分发不起作用,jboss,activemq-artemis,Jboss,Activemq Artemis,在下列第29项之后,重新分配测试不起作用 测试用例:1个jboss主机和2个jboss从机。我在artemis中创建了“respostaCsu”队列,并在其上发布了一条消息。消息是从1号机发来的。这没有关联其correlationId的侦听器,因此没有从队列中删除消息。根据RedHat(再分配延迟=0,消息负载平衡类型=按需)文档,消息应转发到下一台群集计算机(从机-2)。但是,该消息未重定向,并保留在从属1中 有什么建议吗 JBoss EAP 7.1 master domain.xml文件:
...
<socket-binding-group name="full-ha-sockets" default-interface="public">
<socket-binding name="ajp" port="${jboss.ajp.port:8009}"/>
<socket-binding name="http" port="${jboss.http.port:8080}"/>
<socket-binding name="https" port="${jboss.https.port:8443}"/>
<socket-binding name="iiop" interface="unsecure" port="3528"/>
<socket-binding name="iiop-ssl" interface="unsecure" port="3529"/>
<socket-binding name="jgroups-mping" interface="private" port="0" multicast-address="${jboss.default.multicast.address:230.0.0.4}" multicast-port="45700"/>
<socket-binding name="jgroups-tcp" interface="private" port="7600"/>
<socket-binding name="jgroups-udp" interface="private" port="55200" multicast-address="${jboss.default.multicast.address:230.0.0.4}" multicast-port="45688"/>
<socket-binding name="modcluster" port="0" multicast-address="${jboss.modcluster.multicast.address:224.0.1.105}" multicast-port="23364"/>
<socket-binding name="txn-recovery-environment" port="4712"/>
<socket-binding name="txn-status-manager" port="4713"/>
<socket-binding name="messaging-group" interface="private" port="5432" multicast-address="${jboss.default.multicast.address:230.0.0.4}" multicast-port="9876"/>
<outbound-socket-binding name="mail-smtp">
<remote-destination host="localhost" port="25"/>
</outbound-socket-binding>
</socket-binding-group>
...
<subsystem xmlns="urn:jboss:domain:messaging-activemq:2.0">
<server name="default">
<security enabled="false"/>
<cluster user="mbuser" password="mbsenha"/>
<security-setting name="#">
<role name="guest" send="true" consume="true" create-non-durable-queue="true" delete-non-durable-queue="true"/>
</security-setting>
<address-setting name="#" dead-letter-address="jms.queue.DLQ" expiry-address="jms.queue.ExpiryQueue" max-size-bytes="10485760" page-size-bytes="2097152" message-counter-history-day-limit="10" redistribution-delay="0"/>
<address-setting name="jms.#" redistribution-delay="0"/>
<http-connector name="http-connector" socket-binding="http" endpoint="http-acceptor"/>
<http-connector name="http-connector-throughput" socket-binding="http" endpoint="http-acceptor-throughput">
<param name="batch-delay" value="50"/>
</http-connector>
<in-vm-connector name="in-vm" server-id="0">
<param name="buffer-pooling" value="false"/>
</in-vm-connector>
<http-acceptor name="http-acceptor" http-listener="default"/>
<http-acceptor name="http-acceptor-throughput" http-listener="default">
<param name="batch-delay" value="50"/>
<param name="direct-deliver" value="false"/>
</http-acceptor>
<in-vm-acceptor name="in-vm" server-id="0">
<param name="buffer-pooling" value="false"/>
</in-vm-acceptor>
<broadcast-group name="mb-broadcast-group" socket-binding="messaging-group" broadcast-period="2000" connectors="http-connector"/>
<discovery-group name="mb-discovery-group" socket-binding="messaging-group" refresh-timeout="10000"/>
<cluster-connection name="my-cluster" address="jms" connector-name="http-connector" use-duplicate-detection="false" message-load-balancing-type="ON_DEMAND" discovery-group="mb-discovery-group"/>
<jms-queue name="ExpiryQueue" entries="java:/jms/queue/ExpiryQueue"/>
<jms-queue name="DLQ" entries="java:/jms/queue/DLQ"/>
<jms-queue name="solicitacaoCsu" entries="java:/jms/queue/QL.REQ.BKLQ001Z" durable="false"/>
<jms-queue name="respostaCsu" entries="java:/jms/queue/QL.RSP.BKLQ001Z" durable="false"/>
<connection-factory name="InVmConnectionFactory" entries="java:/ConnectionFactory" connectors="in-vm"/>
<connection-factory name="RemoteConnectionFactory" entries="java:jboss/exported/jms/RemoteConnectionFactory" connectors="http-connector" ha="true" block-on-acknowledge="true" reconnect-attempts="-1"/>
<pooled-connection-factory name="activemq-ra" entries="java:/JmsXA java:jboss/DefaultJMSConnectionFactory" connectors="in-vm" transaction="xa"/>
</server>
</subsystem>
。。。
...
重新分发不支持选择器。然而,最初的分布是这样的。因此,您应该在发送请求之前创建消费者,以便在发送回复时消费者在队列中。谢谢大家。
但我找到了解决办法!问题是套接字绑定中的“消息组”标记!我将端口配置为0,多播地址配置为231.7.7.7,重新分发延迟配置为0。这很有效!=)
这是我的Jboss CLI:
/profile=full-ha/subsystem=messaging-activemq/server=default/broadcast-group=bg-group1:remove
/profile=full-ha/subsystem=messaging-activemq/server=default/discovery-group=dg-group1:remove
/socket-binding-group=full-ha-sockets/socket-binding=messaging-group:add(port=0,multicast-address=${jboss.messaging.group.address:231.7.7.7},multicast-port=${jboss.messaging.group.port:9876})
/socket-binding-group=full-ha-sockets/socket-binding=messaging-throughput:add(port=5455)
/profile=full-ha/subsystem=messaging-activemq/server=default/broadcast-group=bg-group1:add(socket-binding=messaging-group,broadcast-period=5000,connectors=[http-connector])
/profile=full-ha/subsystem=messaging-activemq/server=default/discovery-group=dg-group1:add(socket-binding=messaging-group,refresh-timeout=10000)
/profile=full-ha/subsystem=messaging-activemq/server=default/address-setting=#:write-attribute(name=redistribution-delay,value=0)
爱德华多,我不确定我是否正确,但根据文档
中的说明,在将消息从队列重新分发到集群中具有**匹配消费者**的其他节点之前,您可以使用“重新分发延迟”属性设置队列上最后一个消费者关闭后等待的毫秒数。
因此您需要具有匹配的消费者**消费者重新分配工作,在slavesThanks Abhijeet上工作。问题是:传递的消息包含correlationID=10。从机1等待correlationID=15,从机2等待correlationID=10。首先,消息已传递到slave-1,并且correlationID不匹配。从机1应将此消息转发给从机2(最后一个耗电元件已关闭)。但是slave-1不会重新分发消息。在屏幕上,两个奴隶都有消费者,但只有一个拥有正确的correlationID。如果我的回答回答了您的问题,请将其标记为“正确”,以帮助将来有相同问题的其他人。如果不正确,请提供不正确的反馈。谢谢嗨,贾斯汀。谢谢。但我找到了解决办法!问题是套接字绑定中的“消息组”标记!我将端口配置为0,多播地址配置为231.7.7.7,重新分发延迟配置为0。这很有效!