RabbitMQ -- part3 [Publish/Subscribe]

上節(jié)介紹了將每個消息投遞給一個consumer邑遏,本節(jié)介紹Publish/Subscribe(推送梢灭、訂閱)取具,將一個消息投遞到多個consumer价认,實質是通過廣播形式將消息傳遞給所有consumer

RabbitMQ消息模塊的核心理念是producer不直接將消息交付到隊列,并且producer通常不知道將消息交付到哪個隊列中顾患,producer僅僅將消息發(fā)送到 exchange番捂。exchange其實就是一側接受producer交付的消息,另一側將消息推送到隊列中江解。exchange必須知道接收的消息內容设预,然后通過 exchange type 來定義是將消息推送到指定隊列、推送到多個隊列還是直接丟棄消息犁河。

exchanges

1. Exchange

exchange 的有效類型有:direct鳖枕,topic,headers和fanout

這里主要關注"fanout"桨螺,創(chuàng)建并命名為"logs":

channel.exchange_declare(exchange='logs', exchange_type='fanout')

fanout exchange宾符,從字面也是就能知道,它廣播所有的消息到它所知道的隊列灭翔。

可以通過 rabbitmqctl 命令列出當前的exchange:rabbitmqctl list_exchanges

空字符("")代表默認exchange魏烫,消息將會交付到 routing_key 指定的隊列中,前提是此隊列必須存在肝箱。

2. Temporary queues

  • 1.連接到Rabbit的一個臨時隊列(使用隨機名稱命名隊列)则奥,在聲明隊列時不需要指定queue參數:result = channel.queue_declare()

  • 2.一旦consumer連接關閉,則刪除隊列狭园。設置 exclusive 標志:result = channel.queue_declare(exclusive=True)

3. Bindings

bindings

上面已經創(chuàng)建了"fanout exchange"和queue读处,現在需要告訴exchange將消息發(fā)送到queue。(關聯exchange和queue的動作叫: binding)

channel.queue_bind(exchange='logs', queue=result.method.queue) # result.method.queue 是一個隨機的隊列名唱矛,例如:amq.gen-JzTY20BRgKO-HjmUJj0wLg

列出"bindings": rabbitmqctl list_bindings


構建一個日志系統(tǒng)罚舱,由兩個程序組成,第一個發(fā)送日志消息绎谦,第二個接受并且打印
python-three-overall
  1. emit_log.py 提交日志
#!/usr/bin/env python3
# coding=utf-8

import pika

message = ' '.join(sys.argv[1:]) or 'Hello World!'

connection = pika.BlockingConnection(pika.ConnectionParameters("localhost"))
channel = connection.channel()

# 聲明"logs" exchange管闷,類型為fanout(廣播)
channel.exchange_declare(exchange='logs', exchange_type='fanout')

channel.basic_publish(exchange='logs',
                      routing_key='',   # fanout模式,需要提供此參數窃肠,但是忽略此值
                      body=message,
)

print("[x] Sent '%s'" % message)

connection.close()
  1. receive_logs.py 接受并打印日志
#!/usr/bin/env python3
# coding=utf-8

import pika

connection = pika.BlockingConnection(pika.ConnectionParameters("localhost"))
channel = connection.channel()

# 聲明"logs" exchange包个,類型為fanout(廣播)
channel.exchange_declare(exchange="logs", exchange_type="fanout")

# 使用RabbitMQ生成隨機名的臨時隊列,設置exclusive標志冤留,當consumer斷開連接時碧囊,銷毀隊列
result = channel.queue_declare(exclusive=True)

def callback(ch, method, properties, body):
    print('[x] Received %r' % body)

# result.method.queue 隊列名稱
queue_name = result.method.queue

# 綁定exchange和queue
channel.queue_bind(exchange='logs', queue=queue_name)

channel.basic_consume(callback, queue=queue_name, no_ack=True)

print('[*] Waiting for messgaes. To exit press CTRL+C')

channel.start_consuming()

參考文檔:http://www.rabbitmq.com/tutorials/tutorial-three-python.html


最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市纤怒,隨后出現的幾起案子糯而,更是在濱河造成了極大的恐慌,老刑警劉巖泊窘,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件熄驼,死亡現場離奇詭異像寒,居然都是意外死亡,警方通過查閱死者的電腦和手機瓜贾,發(fā)現死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門诺祸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人祭芦,你說我怎么就攤上這事筷笨。” “怎么了实束?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長逊彭。 經常有香客問我咸灿,道長,這世上最難降的妖魔是什么侮叮? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任避矢,我火速辦了婚禮,結果婚禮上囊榜,老公的妹妹穿的比我還像新娘审胸。我一直安慰自己,他們只是感情好卸勺,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布砂沛。 她就那樣靜靜地躺著,像睡著了一般曙求。 火紅的嫁衣襯著肌膚如雪碍庵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天悟狱,我揣著相機與錄音静浴,去河邊找鬼。 笑死挤渐,一個胖子當著我的面吹牛苹享,可吹牛的內容都是我干的。 我是一名探鬼主播浴麻,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼得问,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了软免?” 一聲冷哼從身側響起椭赋,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎或杠,沒想到半個月后哪怔,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年认境,在試婚紗的時候發(fā)現自己被綠了胚委。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡叉信,死狀恐怖亩冬,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情硼身,我是刑警寧澤硅急,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站佳遂,受9級特大地震影響营袜,放射性物質發(fā)生泄漏。R本人自食惡果不足惜丑罪,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一荚板、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧吩屹,春花似錦跪另、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至擦盾,卻和暖如春针姿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背厌衙。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工距淫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人婶希。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓榕暇,卻偏偏與公主長得像,于是被迫代替她去往敵國和親喻杈。 傳聞我的和親對象是個殘疾皇子彤枢,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345