Wildfly14 +无法查找invm队列

时间:2019-04-08 05:14:26

标签: wildfly activemq-artemis

无法通过ConnectionFactory查找invm队列

Hashtable<String, Object> properties = new Hashtable<>();
properties.put("connectionFactory.ConnectionFactory", "(tcp://localhost:8080)?httpUpgradeEnabled=true&retryInterval=3000&reconnectAttempts=-1&initialConnectAttempts=10&maxRetryInterval=3000&clientFailureCheckPeriod=1000");
properties.put(Context.INITIAL_CONTEXT_FACTORY, "org.apache.activemq.artemis.jndi.ActiveMQInitialContextFactory");
InitialContext jndiContext = new InitialContext(properties);
ConnectoryFactory connFactory = (ConnectionFactory) jndiContext.lookup(connectionFactory);
Connection connection = connFactory.createConnection(userName, password);
session = connection.createSession(true, javax.jms.Session.AUTO_ACKNOWLEDGE);

Hashtable<String, Object> properties = new Hashtable<>();
properties.put(Context.INITIAL_CONTEXT_FACTORY, factoryInitial);
InitialContext ctx = new InitialContext(properties);
destination = (Destination) ctx.lookup("dynamicQueues/TestQueue"); //I can't put queue name in jndi.properties

MessageProducer producer = session.createProducer(destination);
producer.send(message, Message.DEFAULT_DELIVERY_MODE, Message.DEFAULT_PRIORITY, msgTTL);
if (session.getTransacted() && session.getAcknowledgeMode() == Session.SESSION_TRANSACTED) {
   session.commit();
}

当我执行以上代码时,它将引发错误,表明队列“ TestQueue”不存在。我已经尝试过使用dynamicQueues / TestQueue和jms / TestQueue查找队列,但是在两种情况下,我都遇到相同的错误

能否让我知道这段代码出了什么问题?

请在以下Wildfly ActiveMQ Artemis配置中查找

<server name="default" persistence-enabled="true">
    <cluster password="${jboss.messaging.cluster.password:CHANGE ME!!}"/>
    <bindings-directory path="/opt/shared/messaging/live/bindings"/>
    <journal-directory path="/opt/shared/messaging/live/journal"/>
    <large-messages-directory path="/opt/shared/messaging/live/largemessages"/>
    <paging-directory path="/opt/shared/messaging/live/paging"/>
    <security-setting name="#">
        <role name="guest" send="true" consume="true" create-durable-queue="true" delete-durable-queue="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" redelivery-delay="60000" max-delivery-attempts="5" max-size-bytes="50485760" page-size-bytes="10485760" address-full-policy="PAGE" redistribution-delay="1000"/>
    <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="bg-group1" jgroups-cluster="activemq-cluster" connectors="http-connector"/>
    <discovery-group name="dg-group1" jgroups-cluster="activemq-cluster"/>
    <cluster-connection name="my-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-queue name="TestQueue" entries="java:/jms/TestQueue java:jboss/exported/jms/TestQueue"/>
    <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>

2 个答案:

答案 0 :(得分:0)

我只想与您分享一些链接,以供进一步阅读。

如果您开始使用wildfly进行开发,那么快速入门是一个很好的入门点。

这里有一个外部客户示例: https://github.com/wildfly/quickstart/tree/14.x/helloworld-jms

这里是所有东西都在wildfly容器中运行的地方: https://github.com/wildfly/quickstart/tree/14.x/helloworld-mdb

您在此处拥有有关wildfly 14中消息传递的常规文档: https://docs.wildfly.org/14/Admin_Guide.html#Messaging

答案 1 :(得分:0)

您正在使用的初始上下文工厂(即org.apache.activemq.artemis.jndi.ActiveMQInitialContextFactory)是仅客户端JNDI实现,可与独立的ActiveMQ Artemis一起使用。由于您使用的是Wildfly,因此应该使用其JNDI实现(即org.wildfly.naming.client.WildFlyInitialContextFactory)。然后,您可以从Wildfly服务器中查找连接工厂和目标,而无需在代码中指定连接工厂URL。

此外,没有“ invm队列”之类的东西。