【问题标题】:Message driven bean doesn't receive messages from topic消息驱动 bean 不接收来自主题的消息
【发布时间】:2018-10-19 19:53:51
【问题描述】:

我正在使用 WildFly AS 并以独立完整配置运行我的 EJB 应用程序。我创建了消息驱动 bean,但由于某种原因,它没有接收消息。

@MessageDriven(name = "receiver",
    activationConfig = {
            @ActivationConfigProperty(
                    propertyName = "destinationType",
                    propertyValue = "javax.jms.Topic"
            ),
            @ActivationConfigProperty(
                    propertyName = "destination",
                    propertyValue = "Ecare"
            ),
            @ActivationConfigProperty(
                    propertyName = "acknowledgeMode",
                    propertyValue = "Auto-acknowledge"
            )})
@ResourceAdapter("activemq-ra.rar")
public class JMSListener implements MessageListener {
    private Logger logger = Logger.getLogger("JMSListener logger");
    private JMSNotifier jmsNotifier = new JMSNotifier();

@Override
public void onMessage(Message message) {
    logger.info("Message received");
    jmsNotifier.notifyAllSubscribers();
}
}

我尝试通过 ActiveMQ 控制台手动从应用程序发送消息。我可以看到他们来了,但 MDB 从不读取任何内容。我唯一的猜测是它可能实际上是在监听来自嵌入服务器的一些 JMS 系统的消息,而我正在将它们发送到独立的 ActiveMQ 系统,但我不知道如何检查它。

补充: 基本上,我在standalone-full.xml 中找到的所有配置都连接到JMS。

<subsystem xmlns="urn:jboss:domain:messaging-activemq:2.0">
        <server name="default">
            <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"/>
            <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>
            <jms-queue name="ExpiryQueue" entries="java:/jms/queue/ExpiryQueue"/>
            <jms-queue name="DLQ" entries="java:/jms/queue/DLQ"/>
            <connection-factory name="InVmConnectionFactory" entries="java:/ConnectionFactory" connectors="in-vm"/>
            <connection-factory name="RemoteConnectionFactory" entries="java:jboss/exported/jms/RemoteConnectionFactory" connectors="http-connector"/>
            <pooled-connection-factory name="activemq-ra" entries="java:/JmsXA java:jboss/DefaultJMSConnectionFactory" connectors="in-vm" transaction="xa"/>
        </server>
    </subsystem>

&lt;subsystem xmlns="urn:jboss:domain:ejb3:5.0"&gt;

        <mdb>
            <resource-adapter-ref resource-adapter-name="${ejb.resource-adapter-name:activemq-ra.rar}"/>
            <bean-instance-pool-ref pool-name="mdb-strict-max-pool"/>
        </mdb>

我正在尝试添加以下配置

<subsystem xmlns="urn:jboss:domain:resource-adapters:2.0">
    <resource-adapters>
        <resource-adapter id="activemq">
            <archive>
                activemq-rar-5.10.0.rar
            </archive>

            <transaction-support>XATransaction</transaction-support>

            <config-property name="UseInboundSession">
                false
            </config-property>

            <config-property name="Password">
                defaultPassword
            </config-property>

            <config-property name="UserName">
                defaultUser
            </config-property>

            <config-property name="ServerUrl">
                tcp://localhost:61616
            </config-property>

            <connection-definitions>
                <connection-definition class-name="org.apache.activemq.ra.ActiveMQManagedConnectionFactory" jndi-name="java:/ConnectionFactory" enabled="true" pool-name="ConnectionFactory">

                    <xa-pool>
                        <min-pool-size>1</min-pool-size>
                        <max-pool-size>20</max-pool-size>
                        <prefill>false</prefill>
                        <is-same-rm-override>false</is-same-rm-override>
                    </xa-pool>

                </connection-definition>
            </connection-definitions>

            <admin-objects>
                <admin-object class-name="org.apache.activemq.command.ActiveMQQueue" jndi-name="java:jboss/activemq/queue/TestQueue" use-java-context="true" pool-name="TestQueue">

                    <config-property name="PhysicalName">
                        activemq/queue/TestQueue
                    </config-property>

                </admin-object>

                <admin-object class-name="org.apache.activemq.command.ActiveMQTopic" jndi-name="java:jboss/activemq/topic/TestTopic" use-java-context="true" pool-name="TestTopic">

                    <config-property name="PhysicalName">
                        activemq/topic/TestTopic
                    </config-property>

                </admin-object>
            </admin-objects>
        </resource-adapter>
    </resource-adapters>
</subsystem>

我也将此资源放在 mdb 标记中,但 deployemt 失败了,因为一些组件已经存在。之后,我尝试删除默认的activemq配置,但是那个时候部署失败了,因为它缺少一些组件。

【问题讨论】:

  • 您能否从您的服务器配置文件中粘贴 ActiveMQ JCA 资源适配器的配置?另外,控制台是否指示有任何消费者连接到队列?
  • @JustinBertram 在控制台中我只看到有多少消息排队,并且总是有 0 个消费者和 0 个出队消息。看起来我的猜测是正确的,我试图从嵌入式 ActiveMQ 接收消息,同时将它们发送到独立的。但是现在我的服务器配置有问题。我已经更新了我的主题,请您检查一下吗?
  • 您是如何发送消息的?您能否提供有关您的制作人的客户端库和配置的详细信息?我看不到您的 MDB 如何连接到在 Wildfly 中运行的 ActiveMQ Artemis 的嵌入式实例,因为它在端口 61616 上没有侦听器,并且默认情况下也不支持 OpenWire。
  • @JustinBertram 我在我的 pom.xml 文件中添加了 activemq-client 依赖项,我正在发送消息,就像这里 activemq.apache.org/hello-world.html 一样。唯一的区别是我使用 ActiveMQConnection.DEFAULT_BROKER_URL 而不是使用“vm://localhost”,我相信它是 localhost:61616。它没有其他配置并且可以正常工作,我认为这是消费者的问题。

标签: java jms ejb activemq wildfly


【解决方案1】:

所以,我花了很多时间试图让它工作,倾斜,停止尝试几天,然后按照这些https://blog.coffeebeans.at/archives/230 说明而不接触standalone-full.xml,一切正常!

【讨论】:

    猜你喜欢
    • 2015-08-29
    • 2018-11-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-11-04
    • 2011-07-15
    相关资源
    最近更新 更多