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

相关推荐
2501_9411458519 小时前
Go语言高效爬虫开发实战:协程与并发请求代码解析
rabbitmq
2501_941870561 天前
Java Spring Boot结合Elasticsearch高性能搜索服务设计与实战经验分享:广州电商商品智能搜索落地
rabbitmq
kong79069282 天前
微服务项目开发环境
微服务·nacos·rabbitmq·开发环境
Bug快跑-12 天前
面向数据密集型应用的Python工程化实践与性能优化策略深度分析与经验分享探索研究篇
rabbitmq
while(努力):进步2 天前
面向移动与云端的Kotlin微服务架构设计与高并发后端性能优化工程化实践经验分享
rabbitmq
debug骑士2 天前
互联网高性能技术系列分享文档(Python / Java / C++ / Go)
rabbitmq
2501_941146702 天前
高并发RPC框架gRPC与Thrift在互联网系统优化实践经验分享
rabbitmq
q***69772 天前
RabbitMQ HAProxy 负载均衡
rabbitmq·负载均衡·ruby
2501_941801762 天前
高性能智能语音识别系统架构设计
rabbitmq
2501_941142642 天前
人工智能与推荐系统在高并发互联网架构中的优化与工程实践经验分享
rabbitmq