RabbitMQ 持久化

交换机持久化

交换器的持久化是通过在声明交换机时是将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 的性能,**如果不要求消息的持久化的场景中,我们尽量不要设置消息的持久化,虽然不是每条消息一到队列就进行持久化,而是使用批量持久化,当消息达到一定数量的时候,我们才进行落盘操作,但还是会降低性能

相关推荐
KIDAKN5 小时前
RabbitMQ 可靠传输性(包括消息确认, 持久性和发送方确认)
java·rabbitmq·java-rabbitmq
hong_zc8 小时前
rabbitmq 重试机制
rabbitmq
iiYcyk11 小时前
RabbitMQ之死信队列
分布式·rabbitmq
hong_zc1 天前
RabbitMQ工作模式(下)
rabbitmq
Cxzzzzzzzzzz1 天前
RabbitMQ 入门与 Go 语言实践
golang·rabbitmq·ruby
零千叶2 天前
【面试】RabbitMQ 常见问题
面试·职场和发展·rabbitmq
kobe_OKOK_2 天前
rabbitmq 入门知识点
分布式·rabbitmq·ruby
王嘉俊9252 天前
深入浅出 全面剖析消息队列(Kafka,RabbitMQ,RocketMQ 等)
分布式·kafka·消息队列·rabbitmq·rocketmq
Zhao_yani2 天前
RabbitMQ相关知识
分布式·rabbitmq