消息队列面试题-RocketMQ

1.为什么要使用消息队列?

消息队列面试题-RocketMQ_第1张图片

2.消息队列有什么优点和缺点?

消息队列面试题-RocketMQ_第2张图片

3.如何解决重复消费?

幂等性

概念:一次和多次请求某一个资源对于资源本身应该具有同样的结果(网络超时等问题除外)。也就是说,其任意多次执行对资源本身所产生的影响均与一次执行的影响相同。

要保证消息的幂等性,这个要结合业务的类型来进行处理。下面提供几个思路供参考:

  1. 可在内存中维护一个set,只要从消息队列里面获取到一个消息,先查询这个消息在不在set里面,如果在表示已消费过,直接丢弃;如果不在,则在消费后将其加入set当中。
  2. 如何要写数据库,可以拿唯一键先去数据库查询一下,如果不存在在写,如果存在直接更新或者丢弃消息。
  3. 如果是写redis那没有问题,每次都是set,天然的幂等性。
  4. 让生产者发送消息时,每条消息加一个全局的唯一id,然后消费时,将该id保存到redis里面。消费时先去redis里面查一下有么有,没有再消费。
  5. 数据库操作可以设置唯一键,防止重复数据的插入,这样插入只会报错而不会插入重复数据。

4.RocketMQ如何保证高可用?

消息队列面试题-RocketMQ_第3张图片

同步复制:保证了我们的热数据。也就是说 主和从保持的数据一致性。

5.RocketMQ的存储机制了解吗?

消息队列面试题-RocketMQ_第4张图片

消息队列面试题-RocketMQ_第5张图片

那么consumer怎么消费呢?

consumer消费到consume queue中的第一个queue,找到第一个数据,怎么确保是第一个数据呢?因为每一个数据的:8 bytes+4 bytes + 8 bytes 也就是20个bytes,所以在queue中从头开始找 找20个bytes,拿到这个数据后,就可以在commitLog文件中找到msgId为1111的数据,则就会拿到commitLog文件中的消息体。

所以根据索引:在根据索引解析里面的偏移量和长度;再去找实际本体存储的commitlog—所以作为消费者也可以快速的消费到消息的。这时候找到消息的时间复杂度是o(1);

在comsume queue中找到消息的时间复杂度是o(1):因为每个消息的固定size是20固定的 所以要不找0-20,20-40,40-60,,,,所以这个找到消息的时间复杂度是o(1);找到消息之后 根据消息里面的8 bytes+4 bytes+8bytes,所以根据这个区commitLog文件中去对应这个具体的消息,其时间复杂度也是o(1);所以对于消费者来说 消费到具体的消息的时间复杂度是o(1)+o(1)=o(1)。

为什么不直接用队列放消息就行了?为什么 偏偏又用了commitLog和consum queue一起?

主要是为了应对多主题或者是海量主题的一个高并发写入。也就是说无论你有多少个主题,我也只有一个文件commitLog,在这个commitLog文件中按照顺序写入。所以这样会针对多个主题的高并发是非常有用的。

6.RocketMQ性能比较高的原因是什么?

消息队列面试题-RocketMQ_第6张图片

7.让你来设计消费队列 你会怎么设计?

消息队列面试题-RocketMQ_第7张图片

8.有几百万消息支持积压几小时,说说怎么解决?

消息队列面试题-RocketMQ_第8张图片

消息队列面试题-RocketMQ_第9张图片

9.RocketMQ中的broker的部署方式?

消息队列面试题-RocketMQ_第10张图片

10.RocketMQ中的broker的刷盘策略有哪些?

消息队列面试题-RocketMQ_第11张图片

11.什么事路由注册?RocketMQ如何进行路由注册?

消息队列面试题-RocketMQ_第12张图片

12.什么是路由发现?RocketMQ是如何进行路由发现的?

13.什么是路由剔除?RocketMQ如何进行路由剔除?

消息队列面试题-RocketMQ_第13张图片

也就是rocketmq使用了定时任务(定期扫描)去查看broker有没有问题,超过120s时,认为其有问题,进行移除。

14.使用rocketmq过程中有遇到什么问题?又是怎么解决的?

1.重复消费问题
2.如果消费者数量超过队列的数量会发生什么?----超出的消费者处于饿死状态,永远不会被消费
3.消息积压问题一个队列只会被一个消费者消费 。这时如果要快速处理积压的消息,可以创建一个新的Topic,配置足够多的MessageQueue。然后把所有消费者节点的目标Topic转向新的Topic,并紧急上线一组新的消费者,只负责消费旧Topic中的消息,并转储到新的Topic中,这个速度是可以很快的。然后在新的Topic上,就可以通过增加消费者个数来提高消费速度了。之后再根据情况恢复成正常情况

15.RocketMQ的整体架构以及每个组件的功能?

16.讲一讲rocketMQ中的分布式事务及实现?

什么是分布式事务?

分布式事务就是指事务的参与者、支持事务的服务器、资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上。以上是百度百科的解释,简单的说,就是一次大的操作由不同的小操作组成,这些小的操作分布在不同的服务器上,且属于不同的应用,分布式事务需要保证这些小操作要么全部成功,要么全部失败。本质上来说,分布式事务就是为了保证不同数据库的数据一致性

消息队列面试题-RocketMQ_第14张图片

17.讲讲RocketMq中事务回查机制的实现?

18.RocketMq在分布式事务中是如何应用的?

消息队列面试题-RocketMQ_第15张图片

消息队列面试题-RocketMQ_第16张图片

你可能感兴趣的:(RabbitMQ,java)