.Net下RabbitMQ的使用(5) -- 持久化

消息的持久化是消息队列必备的功能之一。在这篇文章中,就介绍一下RabbitMQ的持久化机制,和它的使用。

队列的持久化

在前几篇的例子中,我们常常看到如下定义queue的方法:

channel.QueueDeclare("Q1", false, false, false, null);

方法的第四的参数autoDelete,一般都会输入false。文档描述这个参数如果是true的话,意思是:如果这个queue不再使用(没有被订阅)的话,server就会删除它。在我的测试过程中,只要是连接改queue的所有接收者都断开连接的话,该queue就会被删除,即使里面还有没有处理的消息。RabbitMQ的重启也同样会删除他们。如果输入的是false,那与之相连的客户端都断开连接的话,服务是不会删除这个队列的,队列中的消息也就会存在。发送端在没有客户端连接的时候也可以把消息放入改队列,客户端起来的时候,就会得到这些消息。但是如果RabbitMQ服务重启的话,该队列就没有了,里面的消息自然也就没有了。

第三个参数是exclusive,文档描述说,如果是true,那么申明这个queue的connection断了,那么这个队列就被删除了,包括里面的消息。

第二个参数durable,文档描述说,如果是true,则代表是一个持久的队列,那么在服务重启后,也会存在。因为服务会把持久化的queue存放在硬盘上,放服务重启的时候,会重新申明这个queue。当然必须是在autoDelete和exclusive都为false的时候。队列是可以被持久化,但是里面的消息是否为持久化那还要看消息的持久化设置。也就是说,如果重启之前那个queue里面还有没有发出去的消息的话,重启之后那队列里面是不是还存在原来的消息,这个就要取决于发送者在发送消息时对消息的设置了。

 

消息的持久化

接上文,如果要在重启后保持消息的持久化必须设置这个消息是持久化的。设置是在发送者发送的时候,比较简单,代码如下:

IBasicProperties properties = channel.CreateBasicProperties();
properties.DeliveryMode = 2;
channel.BasicPublish("", "TaskQueue", properties, bytes);

DeliveryMode等于2就说明这个消息是persistent的。1是默认是,不是持久的。

在接收者接收消息并处理的时候会出现各种各样的问题:抛出异常导致与RabbitMQ连接断开,程序挂掉,网络问题等等。往往在出现这些问题的时候我们通常都希望队列能保存这些消息,并在程序再次起来的时候能够重新处理,或如果是负载均衡的模式下,能够把这个消息重新分配给其他的同等的接受者来处理。这同样也是RabbitMQ对消息持久化的一种功能。这我们在消息的传输控制中做详细的说明。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RabbitMQ是一个开源的消息中间件,被广泛用于构建可扩展、高可靠性和灵活的应用程序。它基于AMQP(高级消息队列协议)实现,允许不同系统之间进行异步通信,提供了解耦、可靠性以及可扩展性的优势。 在2021年,.NET Core成为.NET框架的主要版本,它是一个跨平台的开发框架,支持Windows、Linux和macOS等操作系统。通过将.NET Core与RabbitMQ结合使用,开发人员可以构建具有高性能和可伸缩性的应用程序,满足日益增长的需求。 使用.NET Core与RabbitMQ,您可以在应用程序中使用RabbitMQ的各种功能和特性。通过RabbitMQ的消息队列,您可以实现异步消息传输,让发送者和接收者之间的耦合度更低。这有助于解耦和提高应用程序的可靠性,因为消息可以在不同的时间和速度进行处理。 .NET Core为使用RabbitMQ提供了丰富的库和工具,包括RabbitMQ.Client库,可以轻松地与RabbitMQ进行交互。通过使用这些库,您可以创建生产者和消费者应用程序,发送和接收消息,并处理各种RabbitMQ交互模式,如发布/订阅、点对点和请求/响应。 此外,.NET Core还提供了一些用于处理RabbitMQ消息的高级功能,如消息序列化、持久化和确认等。这些功能可以帮助您构建可靠和强大的应用程序,确保消息的安全传递和处理。 总之,.NET Core与RabbitMQ的结合可以帮助开发人员构建高性能、可靠和可伸缩的应用程序。通过使用RabbitMQ的消息中间件,您可以实现异步通信和解耦,而.NET Core提供了必要的工具和库来轻松地与RabbitMQ进行交互。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值