导语:
本文主要介绍了关于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()
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中if语句的使用及if-else结构的使用10/06
- ♥ 如何查看python版本08/24
- ♥ 如何使用 print 调试 python3 代码?11/16
- ♥ 如何运行 python ide11/28
- ♥ 如何在mongodb数据库中创建表11/14
- ♥ 安装后如何运行python11/01
内容反馈