ActiveMQ:使用Python訪問ActiveMQ


Windows 10家庭中文版,Python 3.6.4,stomp.py 4.1.21

 

ActiveMQ支持Python訪問,提供了基於STOMP協議(端口為61613)的庫。

ActiveMQ的官文Cross Language Clients中給出了更詳細的介紹,並附有示例代碼,如下圖:

第一行為常規Python訪問,第二行為使用Jython訪問的方式,四個操作。

 

Python訪問ActiveMQ需要使用stomp.py,見其官網

下載官網的代碼,解壓,命令行進入其目錄,使用pyhthon setup.py install即可安裝好,然后就可以使用stomp.py了。

 

官方示例代碼:給隊列test發送一個消息,也可以把第7行的destination的“/queue/”去掉,只剩test。

1 import stomp
2 
3 conn = stomp.Connection()
4 conn.set_listener('', MyListener())
5 conn.start()
6 conn.connect('admin', 'password', wait=True)
7 conn.send(body=' '.join(sys.argv[1:]), destination='/queue/test')
8 conn.disconnect()

測試結果:test隊列接收到消息數量增加了

 

stomp.Connection()默認是connect.StompConnection11(協議1.1),還可以可以選擇1.0、1.2。

 

在官方代碼中,stomp.Connection()的參數為空,實際上可以有很多參數,比如,設置Broker的IP地址和端口,如下:其中的host_and_ports就是設置IP和端口的。

 

IP和端口設置示例:

c = stomp.Connection([('127.0.0.1', 62613)])

 

這里我犯錯了,端口我協程了8161(ActiveMQ的Web訪問的端口),經查詢(百度搜索到stackoverflow.com)才知,STOMP協議用的是61613(ActiveMQ的配置文件中):

 

ActiveMQ官網的四個測試:

發送消息到隊列Queue屬於 點對點模式,不可以重復消費;

發送消息到主題Topic屬於 發布/訂閱模式,可以重復消費;

 1 # Send a Message to an Apache ActiveMQ Queue 
 2 import stomp
 3  
 4 conn = stomp.Connection10()
 5  
 6 conn.start()
 7  
 8 conn.connect()
 9  
10 conn.send('SampleQueue', 'Simples Assim')
11  
12 conn.disconnect()
13 
14 # Receive a Message from an Apache ActiveMQ Queue
15 import stomp
16 import time
17  
18 class SampleListener(object):
19   def on_message(self, headers, msg):
20     print(msg)
21  
22 conn = stomp.Connection10()
23  
24 conn.set_listener('SampleListener', SampleListener())
25  
26 conn.start()
27  
28 conn.connect()
29  
30 conn.subscribe('SampleQueue')
31  
32 time.sleep(1) # secs
33  
34 conn.disconnect()
35 
36 # Send a Message to an Apache ActiveMQ Topic 
37 import stomp
38  
39 conn = stomp.Connection10()
40  
41 conn.start()
42  
43 conn.connect()
44  
45 conn.send('/topic/SampleTopic', 'Simples Assim')
46  
47 conn.disconnect()
48 
49 # Receive a Message from an Apache ActiveMQ Topic (1)
50 import stomp
51 import time
52  
53 class SampleListener(object):
54   def on_message(self, headers, msg):
55     print(msg)
56  
57 conn = stomp.Connection10()
58  
59 conn.set_listener('SampleListener', SampleListener())
60  
61 conn.start()
62  
63 conn.connect()
64  
65 conn.subscribe('/topic/SampleTopic')
66  
67 time.sleep(1) # secs
68  
69 conn.disconnect()
70 
71 # Receive a Message from an Apache ActiveMQ Topic (2)
72 import stomp
73 import time
74  
75 class SampleListener(object):
76   def on_message(self, headers, msg):
77     print(msg)
78  
79 conn = stomp.Connection10()
80  
81 conn.set_listener('SampleListener', SampleListener())
82  
83 conn.start()
84  
85 conn.connect(headers={'client-id':'SampleClient'})
86  
87 conn.subscribe(destination='/topic/SampleTopic', headers={'activemq.subscriptionName':'SampleSubscription'})
88  
89 time.sleep(1) # secs
90  
91 conn.disconnect()

 

參考

什么是分布式消息中間件?

ActiveMQ-為什么需要消息中間件?

消息隊列的兩種模式

消息隊列使用的四種場景介紹

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM