rabbitmq 消息持久化

Posted weiman3389

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rabbitmq 消息持久化相关的知识,希望对你有一定的参考价值。

 

rabbitmq 消息持久化

技术分享 分类:
二:
任务分发 &消息持久化
 
启用多个接收端的时候如果某一个receive 关闭要保证消息有反馈是否收到
 
send端
#-*- coding: UTF-8 -*-
import pika
cred = pika.PlainCredentials(‘zxl‘,‘pwd‘) #账号密码
params = pika.ConnectionParameters(host=‘192.168.110.233‘,port=5672,credentials=cred) #条件设置
connection = pika.BlockingConnection(params) #给定条件
channel = connection.channel()
channel.queue_declare(queue=‘t_list‘,durable=True) #创建一个t_list 队列
for i in range(0,100):
content = ‘ ni hao is hello‘+str(i)
channel.basic_publish(exchange=‘‘,
routing_key=‘t_list‘,
body=content,
properties=pika.BasicProperties(delivery_mode=2) #确保消息持久
)
print(‘send hello‘)
print(channel)
connection.close()
receive 端
#-*- coding: UTF-8 -*-
import pika
import time
cred = pika.PlainCredentials(‘zxl‘,‘pwd‘) #账号密码
params = pika.ConnectionParameters(host=‘192.168.110.233‘,port=5672,credentials=cred) #条件设置
connection = pika.BlockingConnection(params) #给定条件
channel = connection.channel()
channel.queue_declare(queue=‘t_list‘,durable=True)

def callback(ch,method,properties,body):
print " [x] Received %r" % (body,)
time.sleep(2)
ch.basic_ack(delivery_tag = method.delivery_tag)

channel.basic_consume(callback,queue = ‘t_list‘,no_ack = False) #no_ack 自动应答改为False
print("starting")
channel.start_consuming()

 

































以上是关于rabbitmq 消息持久化的主要内容,如果未能解决你的问题,请参考以下文章

RabbitMQ 消息队列学习

RabbitMQ:工作队列模式

RabbitMq-confirm发送消息确认深入探讨

rabbitmq消息真的可以持久化吗

RabbitMQ事务和Confirm发送方消息确认——深入解读

RabbitMQ-消息可靠性&延迟消息