当前位置: 首页 > news >正文

面试题储备-MQ篇 2-说说你对RocketMQ的理解

嗯,RocketMq主要由生产者producer、消费者consumer、broker和nameServer四部分组成。
nameServer启动后会与broker建立长连接,broker启动后会将topic和broker的对应关系通过长连接存储到nameServer,生产者会建立连接从nameServer获取topic对应的broker,给对应的broker发消息,broker接收到消息后将消息存入commitLog文件,消费者也会从nameServer拉取topic对应的broker,再从broker拉取topic对应的commitLog文件里的消息。

问:RocketMq一共有哪些消费模式:

集群模式-每个分组内消息只能被一个实例消费一次
广播模式-每个分组内消息可以被多次消费
一般我们用的都是集群模式,消息被分组内某个实例消费后,就不会再被其他实例消费到,想要消费同一个topic可以再创建一个新的分组消费;

问:RocketMq消费消息是推模式还是拉模式?

api提供了推和拉的方法,但是实际都是使用的拉模式,实际都是消费者从nameServer获取topic对应的broker,从broker的队列里拉取消息

问: RocketMq是如何进行消息的存储的?

broker接收了生产者发送的消息后,会将消息存入commitLog文件中,之后将消息的大小、存储的偏移量等信息存到comsumeQueue文件。在消费者拉取消息的时候,从consumeQueue获取基本信息,再根据消息存放的信息从commitLog文件获取消息

问:RocketMq消息积压问题如何解决?

和rabbitMq消息积压差不多,多线程消费or异步or改批量处理or消息转发后分别处理

问: RocketMq如何保证消息不丢失?

和rabbitMq一样,生产者接收broker返回结果,失败或者异常重试;broker端将消息存入磁盘,并进行主从同步,同步完成再给生产者返回保存成功;消费者端,在mq处理完成后手动提交返回消费完成

http://www.dtcms.com/a/339471.html

相关文章:

  • 基于WebSocket和SpringBoot聊天项目ChatterBox测试报告
  • 怎样平衡NLP技术发展中数据质量和隐私保护的关系?
  • 中科米堆CASAIM自动化三维测量设备测量汽车壳体直径尺寸
  • 多模态大模型应用落地:从图文生成到音视频交互的技术选型与实践
  • 5.1Pina介绍
  • 进程间的通信(管道,信号)
  • 知行社:以爱之名,共筑公益梦想
  • Podman:Mysql(使用卷)
  • 【Goland】:面向对象编程
  • Day 29 类的装饰器
  • 如何将任意文件一键转为PDF?
  • 【PHP】模拟斗地主后端编写
  • Matplotlib数据可视化实战:Matplotlib图表美化与进阶教程
  • 软件系统运维常见问题
  • idea中如何设置文件的编码格式
  • Python Day31 JavaScript 基础核心知识点详解 及 例题分析
  • 【完整源码+数据集+部署教程】太阳能板表面损伤检测图像分割系统源码和数据集:改进yolo11-DynamicHGNetV2
  • 服务器Linux防火墙怎样实现访问控制
  • Nginx前后端分离反代(VUE+FastAPI)
  • (一)八股(数据库/MQ/缓存)
  • 深入理解抽象类
  • C#三大核心特性
  • 小程序插件使用
  • Win/Linux笔记本合盖不睡眠设置指南
  • UART串口通信编程自学笔记30000字,嵌入式编程,STM32,C语言
  • 【软件安装】VScode介绍安装步骤及中文界面设置方法
  • 移动端即时通讯源码/IM聊天源码RainbowChat,纯原生体验丝滑、全源码易二开
  • NestJS 依赖注入方式全解
  • jmetergrafanainfluxdb搭建压测监控平台
  • JavaScript 性能优化实战:从分析到落地的全指南