消息队列RabbitMQ之消息持久化

前置知识

什么是消息队列RabbitMQ?参考博客:消息队列RabbitMQ之初学者
什么是消息队列的消息模型?参考博客:消息队列RabbitMQ之五种消息模型
什么是消息队列的基本消息模型?参考博客:消息队列RabbitMQ之基本消息模型
什么是消息队列的Work队列消息模型?参考博客:消息队列RabbitMQ之Work队列消息模型
什么是消息队列的订阅模型Fanout?参考博客:消息队列RabbitMQ之订阅模型Fanout
什么是消息队列的订阅模型Direct?参考博客:消息队列RabbitMQ之订阅模型Direct
什么是消息队列的订阅模型Topic?参考博客:消息队列RabbitMQ之订阅模型Topic

RabbitMQ消息持久化

为什么需要消息持久化?

之前在消息队列RabbitMQ之基本消息模型中曾经谈过RabbitMQ的手动Ack机制,手动Ack机制可以很好的保证消息被正常消费,即使程序发生异常,消息依然可以保存在消息队列中。

但是如果是消费者还没有消费数据,但是消息队列发生了宕机,导致消息队列中的消息丢失,那又该怎么办呢?
于是就衍生出来了RabbitMQ的持久化机制。

怎么设置消息持久化?

消息队列进行持久化,前提是交换机和队列都需要进行持久化设置。

JavaAPI设置持久化属性

  • 通道声明交换机的时候,最后一个属性为是否持久化,属性值为true即可设置交换机持久化。
//声明交换机exchange,指定类型为fanout,BuiltinExchangeType是一个枚举类,最后一个参数为指定交换机的持久化属性
channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.TOPIC,true);
  • 通道声明队列的时候,第二个属性为是否持久化,属性值为true即可设置队列持久化。
 //使用通道声明一个队列,参数分别为:队列名称,是否持久化,是否为排他队列,是否自动删除,其他属性
channel.queueDeclare(QUEUE_NAME, true, false, false, null);
  • 生产者发送消息的时候,第三个属性为其他属性,可以选择值MessageProperties.PERSISTENT_TEXT_PLAIN来进行消息持久化。
  • MessageProperties.PERSISTENT_TEXT_PLAIN属性的意思是:消息属性:普通持久化文本
//使用通道发送消息到交换机,参数分别为:交换机名称,路由Key,其他属性,消息正文
channel.basicPublish(EXCHANGE_NAME, "insert.user.data", MessageProperties.PERSISTENT_TEXT_PLAIN, insert_message.getBytes());
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值