JAVA面试题:你怎么设计一个消息队列?
1 面試題
寫一個(gè)消息隊(duì)列,你如何進(jìn)行架構(gòu)設(shè)計(jì),說一下你的思路!
2 考點(diǎn)分析
一般面試官要考察兩塊:
(1)你有沒有對(duì)某一個(gè)消息隊(duì)列做過較為深入的原理的了解,或者從整體了解把握住一個(gè)mq的架構(gòu)原理
(2)看看你的設(shè)計(jì)能力,給你一個(gè)常見的系統(tǒng),就是消息隊(duì)列系統(tǒng),看看你能不能從全局把握一下整體架構(gòu)設(shè)計(jì),給出一些關(guān)鍵點(diǎn)出來
說實(shí)話,一般面類似問題的時(shí)候,大部分人基本都會(huì)蒙,因?yàn)槠綍r(shí)從來沒有思考過類似的問題,大多數(shù)人就是平時(shí)埋頭用,從來不去思考背后的一些東西。
類似的問題,經(jīng)常問的還有,如果讓你來設(shè)計(jì)一個(gè)spring框架你會(huì)怎么做?如果讓你來設(shè)計(jì)一個(gè)dubbo框架你會(huì)怎么做?如果讓你來設(shè)計(jì)一個(gè)mybatis框架你會(huì)怎么做?
3 詳解
其實(shí)回答這類問題,說白了,不求你看過那技術(shù)的源碼,起碼你大概知道那個(gè)技術(shù)的基本原理,核心組成部分,基本架構(gòu)構(gòu)成,然后參照一些開源的技術(shù)把一個(gè)系統(tǒng)設(shè)計(jì)出來的思路說一下就好
比如說這個(gè)消息隊(duì)列,我們來從以下幾個(gè)角度來考慮一下
3.1 支持可伸縮性
需要的時(shí)候快速擴(kuò)容,就可增加吞吐量和容量,那怎么搞?
設(shè)計(jì)個(gè)分布式的系統(tǒng)唄,參照一下kafka的設(shè)計(jì)理念,broker - topic - partition,每個(gè)partition放一個(gè)機(jī)器,就存一部分?jǐn)?shù)據(jù)。如果現(xiàn)在資源不夠了,簡(jiǎn)單啊,給topic增加partition,然后做數(shù)據(jù)遷移,增加機(jī)器,不就可以存放更多數(shù)據(jù),提供更高的吞吐量了?
3.2 數(shù)據(jù)落地
那肯定要了,落磁盤,才能保證別進(jìn)程掛了數(shù)據(jù)就丟了。那落磁盤的時(shí)候怎么落啊?順序?qū)?#xff0c;這樣就沒有磁盤隨機(jī)讀寫的尋址開銷,磁盤順序讀寫的性能是很高的,這就是kafka的思路。
3.3 其次你考慮一下你的mq的可用性啊
這個(gè)事兒,具體參考我們之前可用性那個(gè)環(huán)節(jié)講解的kafka的高可用保障機(jī)制。多副本 - leader follower - broker掛了重新選舉leader即可對(duì)外服務(wù)。
3.4 支持?jǐn)?shù)據(jù)0丟失
可以的,參考我們之前說的那個(gè)kafka數(shù)據(jù)零丟失方案
其實(shí)一個(gè)mq肯定是很復(fù)雜的,面試官問你這個(gè)問題,其實(shí)是個(gè)開放題,他就是看看你有沒有從架構(gòu)角度整體構(gòu)思和設(shè)計(jì)的思維以及能力。確實(shí)這個(gè)問題可以刷掉一大批人,因?yàn)榇蟛糠秩似綍r(shí)不思考這些東西。
?
轉(zhuǎn)載于:https://juejin.im/post/5cce8e986fb9a0323d6e1788
總結(jié)
以上是生活随笔為你收集整理的JAVA面试题:你怎么设计一个消息队列?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL HINT:Straight_
- 下一篇: 二级级联菜单---纯js实现