无法使用 Immutant 消息传递连接到队列

问题描述 投票:0回答:1

当前我有一个正在运行的 ActiveMQ 实例,我正在尝试使用 immutant 连接到该实例。目前此连接的代码如下所示;

(defn make-ctx
  []
  (log/debug "making context")
  (let [ctx (m/context :host (:host immutant-host) :port (:port immutant-host))]
    (log/debug "context created")
    ctx))

(defn make-listener
  [ctx]
  (let [listener (m/listen topic #(log/debug %) :context ctx)]
    (log/debug "listener created")
    listener))

(defn immutant-test
  []
  (log/debug "testing immutant messaging with ActiveMQ")
  (let [ctx (make-ctx)
        listener (make-listener ctx)]
  (Thread/sleep 15000)
  (.close listener)))

虽然我的代码没有让它通过make-ctx函数。当它尝试创建上下文时,我收到错误

Exception in thread "main" java.lang.RuntimeException: javax.jms.JMSException: Failed to create session factory
    at org.projectodd.wunderboss.messaging.jms.DestinationUtil.mightThrow(DestinationUtil.java:47)
    at org.projectodd.wunderboss.messaging.jms.JMSMessagingSkeleton.createContext(JMSMessagingSkeleton.java:64)
    at org.projectodd.wunderboss.messaging.jms.JMSMessagingSkeleton.createContext(JMSMessagingSkeleton.java:181)
    at immutant.messaging$context.doInvoke(messaging.clj:84)
    at clojure.lang.RestFn.invoke(RestFn.java:457)
    at jms_test.core$make_ctx.invoke(core.clj:24)
    at jms_test.core$immutant_test.invoke(core.clj:37)
    at jms_test.core$_main.invoke(core.clj:158)
    at clojure.lang.AFn.applyToHelper(AFn.java:152)
    at clojure.lang.AFn.applyTo(AFn.java:144)
    at jms_test.core.main(Unknown Source)
Caused by: javax.jms.JMSException: Failed to create session factory
    at org.hornetq.jms.client.HornetQConnectionFactory.createConnectionInternal(HornetQConnectionFactory.java:673)
    at org.hornetq.jms.client.HornetQConnectionFactory.createConnection(HornetQConnectionFactory.java:112)
    at org.hornetq.jms.client.HornetQConnectionFactory.createConnection(HornetQConnectionFactory.java:107)
    at org.projectodd.wunderboss.messaging.jms.JMSMessagingSkeleton$1.call(JMSMessagingSkeleton.java:73)
    at org.projectodd.wunderboss.messaging.jms.DestinationUtil.mightThrow(DestinationUtil.java:45)
    ... 10 more
Caused by: HornetQConnectionTimedOutException[errorType=CONNECTION_TIMEDOUT message=HQ119013: Timed out waiting to receive cluster topology. Group:null]
    at org.hornetq.core.client.impl.ServerLocatorImpl.createSessionFactory(ServerLocatorImpl.java:946)
    at org.hornetq.jms.client.HornetQConnectionFactory.createConnectionInternal(HornetQConnectionFactory.java:669)
    ... 14 more

不变主机定义为

(def immutant-host {:host "127.0.0.1" :port 61616})

我已经能够使用 clamq 库连接到我的代理,并且能够使用它发送和接收消息。不过,因为应用程序的其余部分是使用不变消息传递构建的,所以如果可能的话,我想坚持使用该库,以避免必须支持多个消息传递库。

clojure messaging activemq-artemis immutant
1个回答
1
投票

Immutant 构建在 HornetQ 之上,因此默认只能连接到 HornetQ 服务器。这是因为 JMS 规范没有提供有线协议,因此每个实现都有自己的实现。但是,如果远程 ActiveMQ 实际上是 Artemis,您可以使用 wunderboss-artemis 来从 Immutant 中使用它(请注意,文章指出您必须使用 Immutant 的增量构建 - 这不再是事实,您可以使用 Immutant 2.1.0)。

如果不是 Artemis,那么以 artemis 版本为指导来实现

wunderboss-activemq
适配器也不会太困难。

© www.soinside.com 2019 - 2024. All rights reserved.