交换机持久化
交换器的持久化是通过在声明交换机时是将durable参数置为true实现的.相当于将交换机的属性在服务器内部保存,当MQ的服务器发生意外或关闭之后,重启RabbitMQ时不需要重新去建立交换机,交换机会自动建立,相当于一直存在。
如果交换器不设置持久化,那么在RabbitMQ服务重启之后,相关的交换机元数据会丢失,对一个长期使用的交换器来说,建议将其置为持久化的.
java
//声明交换机
@Bean("durableExchange")
public Exchange durableExchange() {
return ExchangeBuilder.directExchange(MQConstants.DURABLE_EXCHANGE).durable(true).build();
}
//声明交换机
@Bean("durableExchange2")
public Exchange durableExchange2() {
return ExchangeBuilder.directExchange(MQConstants.DURABLE_EXCHANGE).durable(false).build();
}
通过durable 赋值 true(持久化), false (非持久化) 来设置
队列持久化
如果队列不设置持久化,那么在RabbitMQ服务重启之后,该队列就会被删掉,此时数据也会丢失.(队列没有了,消息也无处可存了)
队列的持久化能保证该队列本身的元数据不会因异常情况而丢失,但是并不能保证内部所存储的消息不会丢失,要确保消息不会丢失,需要将消息设置为持久化.
java
//声明队列
@Bean("durableQueue1")
public Queue durableQueue() {
return QueueBuilder.durable(MQConstants.DURABLE_QUEUE).build();
}
@Bean("durableQueue2")
public Queue durableQueue2() {
return QueueBuilder.nonDurable(MQConstants.DURABLE_QUEUE).build();
}
通过 durable() 设置队列的持久性,nonDurable() 就是设置不持久化的队列
消息持久化
消息的持久化就是当rabbitmq 服务器发生崩溃的时候,在重启之后依旧能看到我们发送过的消息,这就是消息的持久化,消息持久化的前提是队列的持久化,如果队列不持久化,只是设置消息的持久化是没有任何作用的,因为承载消息的容器【队列】都消失了,那消息也会跟着消失
首先确保队列持久化:
java
//声明队列
@Bean("durableQueue1")
public Queue durableQueue() {
return QueueBuilder.durable(MQConstants.DURABLE_QUEUE).build();
}
设置消息的持久化:
NON_PERSISTENT 是非持久化,PERSISTENT是持久化
如果我们需要设置消息的持久化就需要设置PERSISTENT
通过给消息的属性赋值messageObject.getMessageProperties().setDeliveryMode(MessageDeliveryMode.PERSISTENT);
java
@RequestMapping("/durable")
public String durable() {
for (int i = 0; i < 10; i++) {
String message = "durable: " + i;
Message messageObject = new Message(message.getBytes(), new MessageProperties());
//设置发送的消息为持久化
messageObject.getMessageProperties().setDeliveryMode(MessageDeliveryMode.PERSISTENT);
rabbitTemplate.convertAndSend(MQConstants.DURABLE_EXCHANGE, MQConstants.DURABLE_ROUTING_KEY, messageObject);
}
return "消息发送成功";
}
注意:
**消息的持久化是需要通过 rabbitmq 调用linux 内核将消息落入磁盘中实现的,因此消息的持久化会降低我们的rabbitmq 的性能,**如果不要求消息的持久化的场景中,我们尽量不要设置消息的持久化,虽然不是每条消息一到队列就进行持久化,而是使用批量持久化,当消息达到一定数量的时候,我们才进行落盘操作,但还是会降低性能