使用消息驱动Bean的Wildfly JMS主题.每个服务器获取一个MDB



我正在使用Wildfly 25.0.1.preview,并尝试使用JMS在集群中向每个节点发送消息。

到目前为止,我使用的是一个主题,所有内容都可以工作,但只有一个MDB是由消息生成的。MDB是在一个或另一个服务器中随机接收的,所以我认为集群配置不是问题。

我想这是这种情况下的标准行为。然而,有什么方法可以实现我想要做的事情吗?也可以考虑使用JMS的替代方案。

standalone-full-ha.xml的消息传递activemq部分(我也很感激您在这里看到的任何错误(:

<subsystem xmlns="urn:jboss:domain:messaging-activemq:13.0">
<server name="default" persistence-enabled="false">
<security elytron-domain="ApplicationDomain"/>
<journal file-size="1024"/>
<replication-master cluster-name="messaging-cluster" group-name="activemq-group"/>
<security-setting name="#">
<role name="guest" send="true" consume="true" create-non-durable-queue="true" delete-non-durable-queue="true" 
create-durable-queue="true" delete-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"/>
<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"/>
<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"/>
<jgroups-broadcast-group name="bg-group1" jgroups-cluster="activemq-cluster" connectors="http-connector"/>
<jgroups-discovery-group name="dg-group1" jgroups-cluster="activemq-cluster"/>
<cluster-connection name="messaging-cluster" address="jms" connector-name="http-connector" discovery-group="dg-group1"/>
<jms-queue name="ExpiryQueue" entries="java:/jms/queue/ExpiryQueue"/>
<jms-queue name="DLQ" entries="java:/jms/queue/DLQ"/>
<jms-topic name="sfereTopic" entries="jms/topic/sfere java:jboss/exported/jms/topic/sfere"/>
<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>

我的MDB:

@MessageDriven(activationConfig = {
@ActivationConfigProperty(propertyName = "destination", propertyValue = "jms/topic/sfere"),
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "jakarta.jms.Topic") })
public class SfereMessageDrivenBean implements MessageListener {
@Override
public void onMessage(Message message) {

感谢这个问题:

消息驱动的bean不会从集群中的其他节点接收消息

我弄清楚发生了什么。有一个丢失的";集群";标签:

<subsystem xmlns="urn:jboss:domain:messaging-activemq:13.0">
<server name="default" persistence-enabled="false">
<cluster password="Anything" />

一旦添加了它,就会在集群的所有节点中接收到消息。

最新更新