欢迎来到 0713网站目录
登录
作者:yanglbme 
来源:https://github.com/doocs/advanced-JAVA/blob/master/docs/high-concurrency/mq-design.md

 

# 面试官心理分析

 

其实聊到这个问题,一般面试官要考察两块:

 

1、你有没有对某一个消息队列做过较为深入的原理的了解,或者从整体了解把握住一个消息队列的架构原理。

 

2、看看你的设计能力,给你一个常见的系统,就是消息队列系统,看看你能不能从全局把握一下整体架构设计,给出一些关键点出来。

 

说实话,问类似问题的时候,大部分人基本都会蒙,因为平时从来没有思考过类似的问题,大多数人就是平时埋头用,从来不去思考背后的一些东西。类似的问题,比如,如果让你来设计一个 Spring 框架你会怎么做?如果让你来设计一个 Dubbo 框架你会怎么做?如果让你来设计一个 MyBatis 框架你会怎么做?

 

# 面试题剖析

 

其实回答这类问题,说白了,不求你看过那技术的源码,起码你要大概知道那个技术的基本原理、核心组成部分、基本架构构成,然后参照一些开源的技术把一个系统设计出来的思路说一下就好。

 

比如说这个消息队列系统,我们从以下几个角度来考虑一下:

 

首先这个 mq 得支持可伸缩性吧,就是需要的时候快速扩容,就可以增加吞吐量和容量,那怎么搞?设计个分布式的系统呗,参照一下 kafka 的设计理念,broker -> topic -> partition,每个 partition 放一个机器,就存一部分数据。如果现在资源不够了,简单啊,给 topic 增加 partition,然后做数据迁移,增加机器,不就可以存放更多数据,提供更高的吞吐量了?

 

其次你得考虑一下这个 mq 的数据要不要落地磁盘吧?那肯定要了,落磁盘才能保证别进程挂了数据就丢了。那落磁盘的时候怎么落啊?顺序写,这样就没有磁盘随机读写的寻址开销,磁盘顺序读写的性能是很高的,这就是 kafka 的思路。

 

其次你考虑一下你的 mq 的可用性啊?这个事儿,具体参考之前可用性那个环节讲解的 kafka 的高可用保障机制。多副本 -> leader & follower -> broker 挂了重新选举 leader 即可对外服务。

 

能不能支持数据 0 丢失啊?可以的,参考我们之前说的那个 kafka 数据零丢失方案。

 

mq 肯定是很复杂的,面试官问你这个问题,其实是个开放题,他就是看看你有没有从架构角度整体构思和设计的思维以及能力。确实这个问题可以刷掉一大批人,因为大部分人平时不思考这些东西。

特别提示:

推荐

最新

最新文章

关于网站、服务器受攻击问题的相关说明
夏天常喝这3杯水,帮你降火、消暑、祛湿,心脑血管也受益~
夏天不出汗,体内会形成“垃圾”?这4个部位出汗多,可能暗藏健康隐患
KESION(.NET版)安装方法
这个“恐怖游戏”,为什么会在孩子间流行?
Linux系统下已经设置只读文件还是被修改的解决办法
驾考新“捷径”?注意“免考包过”的诈骗陷阱!
不刷牙睡觉VS不刷牙吃早餐,哪个更伤身?答案出乎意料
[原创]批量替换网站程序中的gotoip域名
爱干净的你,这些卫生“好习惯”可能正在“偷”走你的健康!这3个看似偷懒的行为其实没毛病!
网站被反向代理方式镜像处理方法
刘诗诗|绝美
好消息!确定国内 eSIM 要来,但这些设备不能用
地产海报|围炉煮茶活动海报
如何禁用危险的http方法,如TRACE,OPTIONS
虚拟主机设置mime类型(json不能使用需设置)
西部数码网站搭建步骤
李兰迪|壁纸
discuz、ecshop、帝国cms部署https(ssl)后会员无法登录
𝗦𝗵𝗮𝗿𝗲 | 秦岚高清壁纸

猜你想看

怎么做才能远离糖尿病?一图了解
怎么做才能在内卷的职场升职加薪?
如何躲避高速“区间测速”?老司机:搞清楚3点,再不怕扣分!
经常开车的人和不开车的人在驾驶习惯
清汤面的真正做法!这样煮,营养又美味
相比住酒店,为何有些人更倾向于在洗浴中心过夜?说出来你信吗?
桂林六道名菜,您尝过几道?
机油在发动机里六个月不换,会怎样?
解读2019年度中国科学十大进展
存在生命迹象?土卫二上发现生命起源关键物质
汽车保养,这8个坑最常见,很多人掉进去过
全网吹爆哪吒!你永远想不通太乙真人为啥四川口音
住宅风水吉凶口诀
高跟鞋穿对了 脚不疼人更美
重庆“被遗忘”的2座千年古镇,人美景美人还少,知道的游客不多
什么是普拉提?和瑜伽有什么区别?
𝑺𝒉𝒂𝒓𝒆壁纸|陈都灵|女神在世,权威二字
久坐腰疼后背疼?教你几个动作,让你的身体更年轻
汽车空调常见的5种故障,今天一口气搞定
五大轿车“年度销冠”出炉:轩逸稳如狗,丰田最让人出乎意料!