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

Fail to connect to queue with Immutant messaging

目前我有一个 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.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 库连接到我的代理,并且能够使用它发送和接收消息。虽然因为应用程序的其余部分是使用不变的消息传递构建的,所以我想尽可能坚持使用该库,以避免必须支持多个消息传递库。

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

如果不是 Artemis,使用 artemis 版本作为指南实施 wunderboss-activemq 适配器不会太困难。