RabbitMQ—持久化

RabbitMQ—持久化

引言

  • 如何保障当 RabbitMQ 服务停掉以后消息生产者发送过来的消息不丢失?
  • 默认情况下 RabbitMQ 退出或由于某种原因崩溃时,它丢失队列和消息,除非告知它不要这样做。
  • 确保消息不会丢失需要做两件事:我们需要将队列消息都标记为持久化。

队列持久化

如何实现队列持久化?
在声明队列的时候把 durable 参数设置为true即可持久化
在这里插入图片描述
注意点:有相同名字的队列未持久化,需要将该相同名字的队列删除才能持久化
在这里插入图片描述
持久化之后,rabbitmq服务器重启,该队列依旧会存在

消息持久化

如何实现:在生产者发送消息的代码修改属性,将props参数设置为MessageProperties.PERSISTENT_TEXT_PLAIN,即可开启消息持久化
在这里插入图片描述
注意点:

  • 队列持久化必须开启,否则不会生效
  • 消息标记为持久化并不能完全保证不会丢失消息

消息的不公平分发

即能者多劳,假如有两个消费者,一个处理的快,一个处理的慢,那么采用轮询的话,处理的快的消费者就会去等待处理的慢的消费者,这个属于公平分发。而不公平分发,处理的快的不会去等待,而是继续处理下一个消息。

如何开启:在生产者中设置如下参数
在这里插入图片描述
意思就是如果这个消息我还没有处理完或者我还没有应答你,你先别分配给我,我目前只能处理一个任务,然后 rabbitmq 就会把该任务分配给没有那么忙的那个空闲消费者。
优点:提高工作线程的利用率
缺点:如果所有的消费者都没有完成手上任务,队列还在不停的添加新任务,队列有可能就会遇到队列被撑满的情况,这个时候就只能添加新的 worker 或者改变其他存储任务的策略。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值