版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第python使用pika庫調(diào)用rabbitmq參數(shù)使用詳情目錄1、應(yīng)答參數(shù)2、持久化參數(shù)3、分發(fā)參數(shù)前言:
python使用pika庫調(diào)用rabbitmq的參數(shù)有三種方式,分別如下所述:
1、應(yīng)答參數(shù)
auto_ack=False
ch.basic_ack(delivery_tag=method.delivery_tag)
生產(chǎn)者模式:
示例代碼:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建隊(duì)列
channel.queue_declare(queue='hello')
#3.向指定隊(duì)列插入數(shù)據(jù)
channel.basic_publish(exchange='',#簡單模式
routing_key='hello',#指定隊(duì)列
body='HelloWorld!')#向隊(duì)列中添加的數(shù)據(jù)
print("[x]Sent'HelloWorld!'")
運(yùn)行結(jié)果:
消費(fèi)者模式:
示例代碼:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建隊(duì)列
#注意:這一步不是必須的,但是如果消費(fèi)者先啟動(dòng)而不是生成者先啟動(dòng)時(shí),這時(shí)隊(duì)列中還沒有hello隊(duì)列,這時(shí)就會(huì)報(bào)錯(cuò)
channel.queue_declare(queue='hello')
#3.確定回調(diào)函數(shù)
defcallback(ch,method,properties,body):
print("[x]Received%r"%body)
ch.basic_ack(delivery_tag=method.delivery_tag)
#4.確定監(jiān)聽隊(duì)列參數(shù)
channel.basic_consume(queue='hello',
auto_ack=False,#手動(dòng)應(yīng)答方式
on_message_callback=callback)
print('[*]Waitingformessages.ToexitpressCTRL+C')
#5.正式監(jiān)聽
channel.start_consuming()
運(yùn)行結(jié)果:
注意:添加應(yīng)答參數(shù)的好處是當(dāng)消費(fèi)者處理回調(diào)函數(shù)的時(shí),萬一程序報(bào)錯(cuò),此時(shí)數(shù)據(jù)就會(huì)消失的。使用應(yīng)答方式后,消費(fèi)者程序萬一報(bào)錯(cuò),修改完程序后重新啟動(dòng)程序還是可以繼續(xù)消費(fèi)上一次的數(shù)據(jù)的。使用應(yīng)答參數(shù)后,沒處理完一條數(shù)據(jù)都會(huì)給隊(duì)列一個(gè)反饋消息的,也就是說消費(fèi)完一條消息后隊(duì)列才會(huì)刪除這條消息。這種方式效率會(huì)降低一些,根據(jù)項(xiàng)目中數(shù)據(jù)的重要性可以選擇是否需要這個(gè)參數(shù)。
2、持久化參數(shù)
#聲明queue
channel.queue_declare(queue='hello2',durable=True)#若聲明過,則換一個(gè)名字
channel.basic_publish(exchange='',
routing_key='hello2',
body='HelloWorld!',
properties=pika.BasicProperties(
delivery_mode=2,#makemessagepersistent
)
生成者方式:
示例代碼:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建持久化隊(duì)列
#注意:非持久化隊(duì)列不能變持久化隊(duì)列,反之也是這樣的,所有創(chuàng)建隊(duì)列中不能創(chuàng)建和非持久化隊(duì)列重名的隊(duì)列
channel.queue_declare(queue='hello2',durable=True)
#3.向指定隊(duì)列插入數(shù)據(jù)
channel.basic_publish(exchange='',#簡單模式
routing_key='hello2',#指定隊(duì)列
body='HelloWorld!',#向隊(duì)列中添加的數(shù)據(jù)
properties=pika.BasicProperties(
delivery_mode=2,#makemessagepersistent
print("[x]Sent'HelloWorld!'")
運(yùn)行結(jié)果:
消費(fèi)者方式:
示例代碼:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建持久化隊(duì)列
#注意:非持久化隊(duì)列不能變持久化隊(duì)列,反之也是這樣的,所有創(chuàng)建隊(duì)列中不能創(chuàng)建和非持久化隊(duì)列重名的隊(duì)列
#注意:這一步不是必須的,但是如果消費(fèi)者先啟動(dòng)而不是生成者先啟動(dòng)時(shí),這時(shí)隊(duì)列中還沒有hello2隊(duì)列,這時(shí)就會(huì)報(bào)錯(cuò)
channel.queue_declare(queue='hello2',durable=True)
#3.確定回調(diào)函數(shù)
defcallback(ch,method,properties,body):
print("[x]Received%r"%body)
ch.basic_ack(delivery_tag=method.delivery_tag)
#4.確定監(jiān)聽隊(duì)列參數(shù)
channel.basic_consume(queue='hello2',#指定隊(duì)列
auto_ack=False,#手動(dòng)應(yīng)答方式
on_message_callback=callback)
print('[*]Waitingformessages.ToexitpressCTRL+C')
#5.正式監(jiān)聽
channel.start_consuming()
運(yùn)行結(jié)果:
注意:加入持久化參數(shù)的好處,當(dāng)rabbitmq隊(duì)列萬一崩了時(shí),此時(shí)隊(duì)列中的所有數(shù)據(jù)都會(huì)丟失,rabbitmq隊(duì)列中的數(shù)據(jù)是保存在內(nèi)存中,當(dāng)加入持久化參數(shù)后,數(shù)據(jù)將會(huì)保存在硬盤中,rabbitmq崩了或者重啟不會(huì)丟失數(shù)據(jù)。
3、分發(fā)參數(shù)
有兩個(gè)消費(fèi)者同時(shí)監(jiān)聽一個(gè)的隊(duì)列。其中一個(gè)線程sleep2秒,另一個(gè)消費(fèi)者線程sleep1秒,但是處理的消息是一樣多。這種方式叫輪詢分發(fā)(round-robin)不管誰忙,都不會(huì)多給消息,總是你一個(gè)我一個(gè)。想要做到公平分發(fā)(fairdispatch),必須關(guān)閉自動(dòng)應(yīng)答ack,改成手動(dòng)應(yīng)答。使用basicQos(perfetch=1)限制每次只發(fā)送不超過1條消息到同一個(gè)消費(fèi)者,消費(fèi)者必須手動(dòng)反饋告知隊(duì)列,才會(huì)發(fā)送下一個(gè)。
channel.basic_qos(prefetch_count=1)
生產(chǎn)者模式:
示例代碼:【為了產(chǎn)生多條數(shù)據(jù),將此程序執(zhí)行多次】
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建隊(duì)列
channel.queue_declare(queue='hello3')
#3.向指定隊(duì)列插入數(shù)據(jù)
channel.basic_publish(exchange='',#簡單模式
routing_key='hello3',#指定隊(duì)列
body='HelloWorld666!',#向隊(duì)列中添加的數(shù)據(jù)
properties=pika.BasicProperties(
delivery_mode=2,#makemessagepersistent
print("[x]Sent'HelloWorld!'")
運(yùn)行結(jié)果:
消費(fèi)者模式:
示例代碼1:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建隊(duì)列
#注意:這一步不是必須的,但是如果消費(fèi)者先啟動(dòng)而不是生成者先啟動(dòng)時(shí),這時(shí)隊(duì)列中還沒有hello2隊(duì)列,這時(shí)就會(huì)報(bào)錯(cuò)
channel.queue_declare(queue='hello3')
#3.確定回調(diào)函數(shù)
defcallback(ch,method,properties,body):
importtime
time.sleep(15)
print("[x]Received%r"%body)
ch.basic_ack(delivery_tag=method.delivery_tag)
#公平分發(fā),若不加下面這行代碼,默認(rèn)是輪詢分發(fā)
channel.basic_qos(prefetch_count=1)
#4.確定監(jiān)聽隊(duì)列參數(shù)
channel.basic_consume(queue='hello3',#指定隊(duì)列
auto_ack=False,#手動(dòng)應(yīng)答方式
on_message_callback=callback)
print('[*]Waitingformessages.ToexitpressCTRL+C')
#5.正式監(jiān)聽
channel.start_consuming()
運(yùn)行結(jié)果:
示例代碼2:
importpika
#1.連接rabbit
connection=pika.BlockingConnection(pika.ConnectionParameters('192.168.124.104'))
channel=connection.channel()
#2.創(chuàng)建隊(duì)列
#注意:這一步不是必須的,但是如果消費(fèi)者先啟動(dòng)而不是生成者先啟動(dòng)時(shí),這時(shí)隊(duì)列中還沒有hello2隊(duì)列,這時(shí)就會(huì)報(bào)錯(cuò)
channel.queue_declare(queue='hello3')
#3.確定回調(diào)函數(shù)
defcallback(ch,method,properties,body):
importtime
time.sleep(3)
print("[x]Received%r"%body)
ch.basic_ack(delivery_tag=method.delivery_tag)
#公平分發(fā),若不加下面這行代碼,默認(rèn)是輪詢分發(fā)
channel.basic_qos(prefetch_count=
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年惠安縣消防救援大隊(duì)政府專職消防員招聘10人備考題庫及答案詳解一套
- 2026年臨朐縣柳山中心衛(wèi)生院公開招聘工作人員備考題庫及參考答案詳解
- 2026年伊通滿族自治縣事業(yè)單位引進(jìn)人才備考題庫完整答案詳解
- 2026年塔里木大學(xué)公開招聘專任教師備考題庫參考答案詳解
- 2026年度寧夏招錄選調(diào)生選報(bào)備考題庫及答案詳解參考
- 2026年個(gè)舊市潤霖建設(shè)發(fā)展有限責(zé)任公司招聘備考題庫參考答案詳解
- 2026年云錫新材料(東營)有限公司招聘備考題庫及答案詳解一套
- 2026年人保備考題庫科技有限公司招聘備考題庫及完整答案詳解一套
- 2026年臺(tái)州市椒江區(qū)國有資本運(yùn)營集團(tuán)有限公司公開招聘工作人員的備考題庫有答案詳解
- 2026年中復(fù)神鷹碳纖維西寧有限公司招聘備考題庫含答案詳解
- 2024年全國大學(xué)生西門子杯工業(yè)自動(dòng)化挑戰(zhàn)賽-ITEM2-邏輯控制賽項(xiàng)-工程設(shè)拓夢(mèng)者隊(duì)計(jì)文件
- 軌跡大數(shù)據(jù)處理技術(shù)的關(guān)鍵研究進(jìn)展綜述
- 被打和解協(xié)議書范本
- 《糖尿病合并高血壓患者管理指南(2025版)》解讀
- 職業(yè)暴露考試試題及答案
- DB61-T 1843-2024 酸棗種植技術(shù)規(guī)范
- 機(jī)械密封安裝及維護(hù)培訓(xùn)
- 古建筑修繕加固施工方案
- DG-TJ08-19-2023園林綠化養(yǎng)護(hù)標(biāo)準(zhǔn)
- 上海市2024-2025學(xué)年高二上學(xué)期期末考試英語試題(含答案無聽力原文及音頻)
- 實(shí)驗(yàn)室評(píng)審不符合項(xiàng)原因及整改機(jī)制分析
評(píng)論
0/150
提交評(píng)論