更新時(shí)間:2022-12-14 15:49:25 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1493次
現(xiàn)在想要進(jìn)入到一些互聯(lián)網(wǎng)企業(yè)中,都需要掌握java消息隊(duì)列的技能,其原因就是由于目前的用戶量逐漸擴(kuò)大,對(duì)于一些電商的企業(yè)來說遇到秒殺、搶票等高頻業(yè)務(wù)時(shí),服務(wù)器幾乎是扛不住大量QPS,因此,就需要引入消息列隊(duì)來進(jìn)行優(yōu)化,所以,熟知相關(guān)的面試題,對(duì)未來的面試有著決定性的幫助:
1.消息隊(duì)列的應(yīng)用場(chǎng)景有哪些?
答:消息隊(duì)列的應(yīng)用場(chǎng)景如下。
應(yīng)用解耦,比如,用戶下單后,訂單系統(tǒng)需要通知庫存系統(tǒng),假如庫存系統(tǒng)無法訪問,則訂單減庫存將失敗,從而導(dǎo)致訂單失敗。訂單系統(tǒng)與庫存系統(tǒng)耦合,這個(gè)時(shí)候如果使用消息隊(duì)列,可以返回給用戶成功,先把消息持久化,等庫存系統(tǒng)恢復(fù)后,就可以正常消費(fèi)減去庫存了。
削峰填谷,比如,秒殺活動(dòng),一般會(huì)因?yàn)榱髁窟^大,從而導(dǎo)致流量暴增,應(yīng)用掛掉,這個(gè)時(shí)候加上消息隊(duì)列,服務(wù)器接收到用戶的請(qǐng)求后,首先寫入消息隊(duì)列,假如消息隊(duì)列長(zhǎng)度超過最大數(shù)量,則直接拋棄用戶請(qǐng)求或跳轉(zhuǎn)到錯(cuò)誤頁面。
日志系統(tǒng),比如,客戶端負(fù)責(zé)將日志采集,然后定時(shí)寫入消息隊(duì)列,消息隊(duì)列再統(tǒng)一將日志數(shù)據(jù)存儲(chǔ)和轉(zhuǎn)發(fā)。
2.RabbitMQ 有哪些優(yōu)點(diǎn)?
答:RabbitMQ 的優(yōu)點(diǎn)如下:
可靠性,RabbitMQ 的持久化支持,保證了消息的穩(wěn)定性;
高并發(fā),RabbitMQ 使用了 Erlang 開發(fā)語言,Erlang 是為電話交換機(jī)開發(fā)的語言,天生自帶高并發(fā)光環(huán)和高可用特性;
集群部署簡(jiǎn)單,正是因?yàn)?Erlang 使得 RabbitMQ 集群部署變的非常簡(jiǎn)單;
社區(qū)活躍度高,因?yàn)?RabbitMQ 應(yīng)用比較廣泛,所以社區(qū)的活躍度也很高;
解決問題成本低,因?yàn)橘Y料比較多,所以解決問題的成本也很低;
支持多種語言,主流的編程語言都支持,如 Java、.NET、PHP、Python、JavaScript、Ruby、Go 等;
插件多方便使用,如網(wǎng)頁控制臺(tái)消息管理插件、消息延遲插件等。
3.RabbitMQ 有哪些重要的角色?
答:RabbitMQ 包含以下三個(gè)重要的角色:
生產(chǎn)者:消息的創(chuàng)建者,負(fù)責(zé)創(chuàng)建和推送數(shù)據(jù)到消息服務(wù)器;
消費(fèi)者:消息的接收方,用于處理數(shù)據(jù)和確認(rèn)消息;
代理:就是 RabbitMQ 本身,用于扮演“快遞”的角色,本身不生產(chǎn)消息,只是扮演“快遞”的角色。
4.RabbitMQ 有哪些重要的組件?它們有什么作用?
答:RabbitMQ 包含的重要組件有:ConnectionFactory(連接管理器)、Channel(信道)、Exchange(交換器)、Queue(隊(duì)列)、RoutingKey(路由鍵)、BindingKey(綁定鍵) 等重要的組件,它們的作用如下:
ConnectionFactory(連接管理器):應(yīng)用程序與 RabbitMQ 之間建立連接的管理器,程序代碼中使用;
Channel(信道):消息推送使用的通道;
Exchange(交換器):用于接受、分配消息;
Queue(隊(duì)列):用于存儲(chǔ)生產(chǎn)者的消息;
RoutingKey(路由鍵):用于把生成者的數(shù)據(jù)分配到交換器上;
BindingKey(綁定鍵):用于把交換器的消息綁定到隊(duì)列上。
運(yùn)行流程,如下圖所示:
5.什么是消息持久化?
答:消息持久化是把消息保存到物理介質(zhì)上,以防止消息的丟失。
6.RabbitMQ 要實(shí)現(xiàn)消息持久化,需要滿足哪些條件?
答:RabbitMQ 要實(shí)現(xiàn)消息持久化,必須滿足以下 4 個(gè)條件:
投遞消息的時(shí)候 durable 設(shè)置為 true,消息持久化,代碼:channel.queueDeclare(x, true, false, false, null),參數(shù) 2 設(shè)置為 true 持久化;
設(shè)置投遞模式 deliveryMode 設(shè)置為 2(持久),代碼:channel.basicPublish(x, x, MessageProperties.PERSISTENT TEXT PLAIN,x),參數(shù) 3 設(shè)置為存儲(chǔ)純文本到磁盤;
消息已經(jīng)到達(dá)持久化交換器上;
消息已經(jīng)到達(dá)持久化的隊(duì)列。
以上就是“2023的Java消息隊(duì)列面試題,需要我們熟知”,你能回答上來嗎?如果想要了解更多的Java面試題相關(guān)內(nèi)容,可以關(guān)注動(dòng)力節(jié)點(diǎn)Java官網(wǎng)。
相關(guān)閱讀
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743