安装操作库
pip install stomp.py
基本写法:
# -*-coding:utf-8-*-
import stomp
import time
queue_name = '/queue/SampleQueue'
topic_name = '/topic/SampleTopic'
listener_name = 'SampleListener'
class SampleListener(object):
def on_message(self, headers, message):
print 'headers: %s' % headers
print 'message: %s' % message
# 推送到队列queue
def send_to_queue(msg):
conn = stomp.Connection10([('127.0.0.1',61613)])
conn.start()
conn.connect()
conn.send(queue_name, msg)
conn.disconnect()
#推送到主题
def send_to_topic(msg):
conn = stomp.Connection10([('127.0.0.1',61613)])
conn.start()
conn.connect()
conn.send(topic_name, msg)
conn.disconnect()
##从队列接收消息
def receive_from_queue():
conn = stomp.Connection10([('127.0.0.1',61613)])
conn.set_listener(listener_name, SampleListener())
conn.start()
conn.connect()
conn.subscribe(queue_name)
time.sleep(1) # secs
conn.disconnect()
##从主题接收消息
def receive_from_topic():
conn = stomp.Connection10([('127.0.0.1',61613)])
conn.set_listener(listener_name, SampleListener())
conn.start()
conn.connect()
conn.subscribe(topic_name)
while 1:
send_to_topic('topic')
time.sleep(3) # secs
conn.disconnect()
if __name__=='__main__':
# send_to_queue('len 123')
# receive_from_queue()
receive_from_topic()
发送数据到队列
发送端
import stomp
import time
# 通过调用stomp下的Connection10方法,创建连接,指定ip和端口
conn = stomp.Connection10([("47.dsadsa74.89", 61613)])
# 启动,连接创建完成
conn.start()
# 但是activemq是需要账号密码的,因此这里连接到指定用户上面
conn.connect(username="admin", passcode="admin", wait=True)
# 发送消息
for i in range(10):
# 第一个参数:队列的名称
# 第二个参数:消息的内容
conn.send("queue1", f"message1:{i}")
time.sleep(3)
# 断开连接
conn.disconnect()
接收端
import stomp
class SampleListener(stomp.ConnectionListener):
def on_message(self, headers, message):
# headers是一个字典,里面很多内容,是一个字典,headers['destination']是对应的队列名称
print(f"headers:{headers['destination']}, message:{message}")
def on_error(self, headers, message):
print(f"headers:{headers['destination']}, message:{message}")
# 同样创建一个连接
conn = stomp.Connection10([("47.9dsad.89", 61613)])
# 绑定监听器,我们这里只有一个,所以名字什么的无所谓
conn.set_listener("", SampleListener())
# 启动
conn.start()
# 连接到指定用户
conn.connect(username="admin", passcode="admin", wait=True)
# 订阅到指定的队列,这个要和发送端发送的队列保持一致
# 当发送端有消息过来时,消息的内容会自动传递到SampleListener类下的on_message的message参数里。headers则包含了一些额外信息,比如时间戳、队列名等等
# 当然,如果有错误就会传到on_error中,不过这里没有定义,可以的话定义一下也是好的,参数和on_message是一样的
conn.subscribe("queue1")
# 让程序不停下,不然程序立马就结束了
while True:
pass
"""
headers:/queue/queue1, message:message1:0
headers:/queue/queue1, message:message1:1
headers:/queue/queue1, message:message1:2
headers:/queue/queue1, message:message1:3
headers:/queue/queue1, message:message1:4
headers:/queue/queue1, message:message1:5
headers:/queue/queue1, message:message1:6
headers:/queue/queue1, message:message1:7
headers:/queue/queue1, message:message1:8
headers:/queue/queue1, message:message1:9
"""
同时指定多个消费者
发送端
import stomp
conn = stomp.Connection10([("47.94dasd.89", 61613)])
conn.start()
conn.connect(username="admin", passcode="admin", wait=True)
for i in range(10):
conn.send("queue1", f"message1:{i}")
conn.send("queue2", f"message2:{i}")
conn.disconnect()
接收端1
import stomp
class SampleListener(stomp.ConnectionListener):
def on_message(self, headers, message):
print(f"headers:{headers['destination']}, message:{message}")
def on_error(self, headers, message):
print(f"headers:{headers['destination']}, message:{message}")
conn = stomp.Connection10([("47.dasdas4.89", 61613)])
conn.set_listener("", SampleListener())
conn.start()
conn.connect(username="admin", passcode="admin", wait=True)
conn.subscribe("queue1")
while True:
pass
接收端2
import stomp
class SampleListener(stomp.ConnectionListener):
def on_message(self, headers, message):
print(f"headers:{headers['destination']}, message:{message}")
def on_error(self, headers, message):
print(f"headers:{headers['destination']}, message:{message}")
conn = stomp.Connection10([("47.9dasdsa89", 61613)])
conn.set_listener("", SampleListener())
conn.start()
conn.connect(username="admin", passcode="admin", wait=True)
conn.subscribe("queue1")
while True:
pass
参考: