Java使用RabbitMQ(四)--消息持久化

消息持久化
消息确认,保证了消费者die时,消息不丢失。
而消息持久化,则是为了保证RabbitMQ 怠机时,消息不丢失。

消息持久化需要以下操作:

boolean durable = true;
channel.queueDeclare("hello", durable, false, false, null);

需要注意的是,RabbitMQ不允许修改已经定义过的队列的属性,所以队列已经被声明过的话,就不能再修改它的持久化策略。

以上操作是保证队列 是持久化的,但是重启rabbitMQ后会发现,消息丢失了,队列还在。所以还需要对消息持久化。

channel.basicPublish("",queueName, MessageProperties.PERSISTENT_TEXT_PLAIN,(i+++message).getBytes("utf-8"));

这样即使rabbitMQ 在运行时down了,也不会丢失消息。

生产消息放到 queue声明必须和消费方的queue声明一致,不然消费方获取消息时会报错。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值