9.30学习

1.如何保证顺序消费

●单 topic,单partition,单 consumer,单线程消费,吞吐量低,不推荐

●如只需保证单key有序,为每个key申请单独内存 queue,每个线程分别消费一个内存 queue 即可,这样就能保证单key(例如用户id、活动id)顺序性。

2.(线上)如何解决积压消费

●修复consumer,使其具备消费能力,并且扩容N台

●写一个分发的程序,将Topic均匀分发到临时Topic中

●同时起N台consumer,消费不同的临时Topic

3.如何避免消息积压

●提高消费并行度

●批量消费

●减少组件IO的交互次数

●优先级消费

4.如何设计消息队列

需要支持快速水平扩容,broker+partition,partition放不同的机器上,增加机器时将数据根据topic做迁移,分布式需要考虑一致性、可用性、分区容错性

●一致性:生产者的消息确认、消费者的幂等性、Broker的数据同步

●可用性:数据如何保证不丢不重、数据如何持久化、持久化时如何读写

●分区容错:采用何种选举机制、如何进行多副本同步

●海量数据:如何解决消息积压、海量Topic性能下降

性能上,可以借鉴时间轮、零拷贝、IO多路复用、顺序读写、压缩批处理

相关推荐
啥咕啦呛23 分钟前
第一周Java学习自测题目
学习
Xudde.35 分钟前
班级作业笔记报告0x05
笔记·学习·安全·web安全
星幻元宇VR44 分钟前
VR科普单车|提升青少年交通安全意识的新工具
科技·学习·安全·生活·vr
_李小白1 小时前
【OSG学习笔记】Day 24: Texture2D 与 Image
android·笔记·学习
笨小古2 小时前
VLA学习笔记——持续更新中
学习·机器人·大模型·具身智能·vla
solicitous2 小时前
遇到一个口头机遇的答辩准备2(ai告诉的要点)
学习·生活
青衫码上行2 小时前
【从零开始学习JVM】内存模型+堆栈的区别
java·jvm·学习·面试
艾莉丝努力练剑2 小时前
【Linux线程】Linux系统多线程(二):线程的优缺点
linux·运维·服务器·c++·学习
艾莉丝努力练剑2 小时前
【Linux线程】Linux系统多线程(一):线程概念
java·linux·运维·服务器·开发语言·学习·线程
嵌入式小企鹅2 小时前
Claude开源风暴?半导体设备突破?
大数据·人工智能·学习·开源·嵌入式·半导体·ai芯片