准备
1、python需要安装stomp,stomp包的安装比较麻烦,建议在网上直接下载.whl文件,然后本地安装
2、本机需要安装acitvemq,安装过程参考[https://blog.csdn.net/weixin_41806489/article/details/104997519]
(https://www.csdn.net/).
注意: 一般用python是通过stomp协议进行通讯
操作过程
1、生产方
prublishi.py
import time
import sys
import os
import stomp
import time
import sys
import os
import stomp
# user = os.getenv("ACTIVEMQ_USER") or "admin"
user = "admin"
# password = os.getenv("ACTIVEMQ_PASSWORD") or "password"
password = "admin"
# host = os.getenv("ACTIVEMQ_HOST") or "localhost"
host = "localhost"
# port = os.getenv("ACTIVEMQ_PORT") or 61613
# port = os.getenv("ACTIVEMQ_PORT") or 61613
port = 61613
dest="test"
messages = 10000
data = "test from BeijingJiaotong"
conn = stomp.Connection(host_and_ports=[(host, port)])
# conn.start()
conn.connect(login=user, passcode=password)
for i in range(0, messages):
conn.send(body=str(i), destination=dest, persistent='false')
# conn.send(body="SHUTDOWN", destination=dest, persistent='false')
conn.disconnect()
2、消费者
listener.py
import sys
import os
import stomp
user = "admin"
password = "admin"
host = "127.0.0.1"
port = 61613
dest="test"
destination = sys.argv[1:2] or ["/topic/event"]
print(sys.argv)
destination = destination[0]
class MyListener(object):
def __init__(self, conn):
self.conn = conn
self.count = 0
self.start = time.time()
def on_error(self, headers, message):
print('received an error %s' % message)
def on_message(self, headers, message):
print(message)
if message == "SHUTDOWN":
conn.disconnect()
sys.exit(0)
else:
print(message)
conn = stomp.Connection(host_and_ports=[("localhost", 61613)])
conn.set_listener('', MyListener(conn))
# conn.start()
conn.connect(login=user, passcode=password)
conn.subscribe(destination=dest, ack='auto', id="")
print("Waiting for messages...")
while 1:
time.sleep(10)