消息队列RabbitMQ之消息持久化

文章目录

  • 前置知识
  • RabbitMQ消息持久化
    • 为什么需要消息持久化?
    • 怎么设置消息持久化?
  • JavaAPI设置持久化属性

前置知识

什么是消息队列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());

你可能感兴趣的:(消息队列,rabbitmq,队列,java)