MQ常见面试题

消息中间件

 

什么是MQ

 

为什么要使用MQ

 

 

1、如何避免消息重复投递和重复消费

在生产数据时,消自体中必须要有一个bizId作为去重依据

在消费一条消息的时候,自己判断一下是否已经消费过了

2、消息丢失,如何保证消息的可靠性传输

消息丢失,可能出现在生产者,MQ,消费者;

生产者丢失:生产者发送数据到MQ的时候,可能因为网络问题半路搞丢了。

可以选择MQ的事务功能,但是会降低吞吐量;

可以使用MQ的发送确认模式,发送消息给MQ之后等待MQ回传确认消息,自己需要维护MQ分配的唯一ID

MQ中丢失:MQ开启持久化,把消息持久化到磁盘

消费者丢失:接收到消息,还没处理,进程挂掉了;

在消息处理完成之后,向MQ发送确认消息。

3、如何保证消息的顺序性

场景:一个queue对应多个consumer,无法保证顺序

保证顺序:一个queue对应一个consumer

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值