【发布时间】:2014-12-23 06:28:40
【问题描述】:
我有一个使用 Stomp 用 Python 编写的 JMS 客户端。我正在运行 Apache activemq 5.10.0。
我有一个名为 TEST 的队列,我的客户端打印日志消息说它正在从队列中读取消息,但是我的 onMessage 方法中的打印语句不起作用。 ActiveMQ 显示客户端已读取消息,Stomp 库中的记录器打印消息,但 onMessage() 打印语句没有显示出来。
有什么建议吗?
代码如下:
import time
import sys
import logging
import stomp
from stomp import ConnectionListener
queuename = sys.argv[1]
logging.basicConfig( level=logging.DEBUG)
class MyListener(ConnectionListener):
message_count = 0
def on_error(self, headers, message):
print 'received an error %s' % message
# onMessage is WRONG - should be on_message
# def onMessage(self, headers, message):
def on_message(self, headers, message):
print headers
print str(message)
print type(message)
print "Message %d" %(message_count)
message_count = message_count + 1
print 'received a message ...%s...' % message
conn = stomp.Connection()
conn.set_listener('', MyListener())
conn.start()
conn.connect()
queue = '/queue/%s' % queuename
print "Queue is [%s]" % queue
print "subscribe: %s" % conn.subscribe
conn.subscribe(destination=queue, id=123421, ack='auto')
while 1:
time.sleep(2)
【问题讨论】: