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

相关推荐
ICollection8 小时前
RabbitMQ的安装集群、镜像队列配置
消息队列·rabbitmq·集群
微步_ym8 小时前
RabbitMQ:在Linux上安装RabbitMQ
linux·rabbitmq·erlang
共饮一杯无12 小时前
在 Windows 系统上怎么使用rabbitmq相关命令,比如:rabbitmqctl list_queues 命令
windows·rabbitmq·rabbitmq命令
xrkhy21 小时前
分布式之RabbitMQ的使用(2)
分布式·rabbitmq
Z_z在努力1 天前
【rabbitmq 高级特性】全面详解RabbitMQ TTL (Time To Live)
分布式·rabbitmq
weixin_436525071 天前
芋道源码 - 连接消息队列 rabbitmq
分布式·rabbitmq
即兴随缘1 天前
【RabbitMQ】消息可靠性保障
rabbitmq·.net
Flash Dog1 天前
【RabbitMQ】原理解析
分布式·rabbitmq
飞鱼&2 天前
RabbitMQ-高可用机制
java·rabbitmq·java-rabbitmq
weixin_436525072 天前
芋道源码 - RabbitMQ + WebSocket 实现分布式消息推送
分布式·websocket·rabbitmq