python rabbitmq是什麼

post200發表於2021-09-11

python rabbitmq是什麼

1、當資訊在一個佇列中變成死信時,可以重新傳送到DLX,繫結DLX的佇列稱為rabbitmq。

也叫死信佇列。

2、常用於訂單超時自動取消,會議預訂提前提醒等等。

例項

import pika
import json
import time
 
credentials = pika.PlainCredentials('admin', 'admin')  # mq使用者名稱和密碼
# 虛擬佇列需要指定引數 virtual_host,如果是預設的可以不填。
connection = pika.BlockingConnection(pika.ConnectionParameters(host='127.0.0.1', port=5672, credentials=credentials))
channel = connection.channel()
# 宣告訊息佇列,訊息將在這個佇列傳遞,如不存在,則建立
queue_name = "delay_queue_a"
exchange = 'delay_exchange_a'
routing_key = 'delay_routing_key_a'
dead_letter_exchange = 'dead_exchange_a'  # 'amq.direct'#'dead_exchange_a'
dead_letter_routing_key = 'dead_letter_routing_key_a'  # 'dead_queue_a'#'dead_letter_routing_key_a'
arguments = {
    "x-message-ttl": 5000,
    'x-dead-letter-exchange': dead_letter_exchange,
    'x-dead-letter-routing-key': dead_letter_routing_key
}
 
channel.confirm_delivery()
 
channel.exchange_declare(exchange=exchange, durable=True, exchange_type='direct')
result = channel.queue_declare(queue=queue_name, durable=False, arguments=arguments)
channel.queue_bind(exchange=exchange, queue=queue_name, routing_key=routing_key)
for i in range(10):
    message = json.dumps({'OrderId': i})
    # 向佇列插入數值 routing_key是佇列名
    channel.basic_publish(exchange=exchange, routing_key=routing_key, body=message,
                          properties=pika.BasicProperties(delivery_mode=2))
    print(message)
    time.sleep(1.5)
 
connection.close()

以上就是python rabbitmq的介紹,希望對大家有所幫助。更多Python學習指路:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2249/viewspace-2828067/,如需轉載,請註明出處,否則將追究法律責任。

相關文章