首页 > 编程语言 > 详细

python连接activemq

时间:2019-07-06 21:31:09      阅读:273      评论:0      收藏:0      [点我收藏+]

介绍

activeMQ是一款消息队列,关于消息队列是什么这里就不再介绍了,这里只介绍如何使用python去连接activemq进行消息的发送和接收。既然都用python去连接了,那么对于消息队列是什么也就无需在此介绍了

python连接activemq,可以使用stomp这个模块,直接pip install stomp.py即可,注意结尾的.py。


发送数据到队列

发送端

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

此时让两个接收端先启动

技术分享图片

技术分享图片

可以看到,此时两个接收端都在处于阻塞状态,等待数据。

此时启动发送端

技术分享图片

技术分享图片

两个接收端瞬间接收到数据,可以看到是刚好错开发送的,说明activemq有负载均衡的效果。

python连接activemq

原文:https://www.cnblogs.com/traditional/p/11144123.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!