RabbitMQ面试题

概念

RabbitMQ是消息中间件,采用的erlang语言,而这个语言本身就是支持并发的。

在项目中运用的场景是我们的订单数据修改时,需要把订单的状态同步给第三方系统,在这个对接过程,我们将消息发送到RabbitMQ上,而RabbitMQ再把消息推给第三方系统。

几种模式

1.单发送单接收

2.单发送多接收

3.发布订阅模式

4.按topic发送接收

如何保证数据不丢失

在整个发送消息,消费消息的过程中,可能三个地方存在问题:

1.发送时,消息由于网络问题,半路搞丢。

解决方法:

  • a.同步。采用事务管理,开启事务,在发送消息的时候,如果mq没有接受到消息,则抛出异常,本地捕获异常并重试。
  • b.异步。写入时可以回调本地接口,确认机制。(建议使用)

2.MQ服务器本身的问题。如果他还没来得及把消息发送消费端就挂了,这个时候消息就丢失了。

解决方法:(持久化操作)

  • a.创建队列时,设置其为持久化。
  • b.消息的deliveryMode为2。

3.在消费的时候,消息由于网络问题,半路搞丢。

解决方法:消费者在接收到消息先执行业务代码,等结束时,再告诉服务器已经执行完,再执行删除操作。

如何避免数据重复消费

这个RabbitMQ认为不是服务器的问题,而是我们的代码问题。

所以我们的解决方法是在消费端进行控制,拥有一个业务id,人工去重。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值