如何实现队列持久化?
在声明队列的时候把 durable 参数设置为true即可持久化

注意点:有相同名字的队列未持久化,需要将该相同名字的队列删除才能持久化

持久化之后,rabbitmq服务器重启,该队列依旧会存在
如何实现:在生产者发送消息的代码修改属性,将props参数设置为MessageProperties.PERSISTENT_TEXT_PLAIN,即可开启消息持久化

注意点:
即能者多劳,假如有两个消费者,一个处理的快,一个处理的慢,那么采用轮询的话,处理的快的消费者就会去等待处理的慢的消费者,这个属于公平分发。而不公平分发,处理的快的不会去等待,而是继续处理下一个消息。
如何开启:在生产者中设置如下参数

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