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

时间:2015-09-29 18:25:58

标签: clojure activemq messaging immutant

目前我有一个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

immutant-host定义为

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

我已经能够使用clamq libray连接到我的经纪人,并且能够发送和接收消息。虽然因为应用程序的其余部分是使用不变的消息传递构建的,但是如果可能的话,我希望坚持使用该库来避免支持多个消息传递库。

1 个答案:

答案 0 :(得分:1)

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

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