0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Java后端工程師的面試經(jīng)歷

工程師人生 ? 來源:工程師吳畏 ? 2019-06-28 16:25 ? 次閱讀

經(jīng)過半年的沉淀,加上對MySQL,redis和分布式這塊的補(bǔ)齊,終于開始重拾面試信心,再次出征。

鵝廠

面試職位:go后端開發(fā)工程師,接受從Java轉(zhuǎn)語言

都知道鵝廠是cpp的主戰(zhàn)場,而以cpp為背景的工程師大都對os,network這塊要求特別高,不像是Java這種偏重業(yè)務(wù)層的語言,之前面試Java的公司側(cè)重還是在數(shù)據(jù)結(jié)構(gòu)、網(wǎng)絡(luò)、框架、數(shù)據(jù)庫和分布式。所以O(shè)S這塊吃的虧比較大

一面基礎(chǔ)技術(shù)面

電話面試,隨便問了些技術(shù)問題,最后還問了個(gè)LeetCode里面medium級別的算法題,偏簡單

redis有沒有用過,常用的數(shù)據(jù)結(jié)構(gòu)以及在業(yè)務(wù)中使用的場景,redis的hash怎么實(shí)現(xiàn)的,rehash過程講一下和JavaHashMap的rehash有什么區(qū)別?redis cluster有沒有了解過,怎么做到高可用的?redis的持久化機(jī)制,為啥不能用redis做專門的持久化數(shù)據(jù)庫存儲?

了不了解tcp/udp,說下兩者的定義,tcp為什么要三次握手和四次揮手?tcp怎么保證有序傳輸?shù)?,講下tcp的快速重傳和擁塞機(jī)制,知不知道time_wait狀態(tài),這個(gè)狀態(tài)出現(xiàn)在什么地方,有什么用?(參考quic

知道udp是不可靠的傳輸,如果你來設(shè)計(jì)一個(gè)基于udp差不多可靠的算法,怎么設(shè)計(jì)?

http與https有啥區(qū)別?說下https解決了什么問題,怎么解決的?說下https的握手過程。

看你項(xiàng)目里面用了etcd,講解下etcd干什么用的,怎么保證高可用和一致性?

既然你提到了raft算法,講下raft算法的基本流程?raft算法里面如果出現(xiàn)腦裂怎么處理?有沒有了解過paxos和zookeeper的zab算法,他們之前有啥區(qū)別?

你們后端用什么數(shù)據(jù)庫做持久化的?有沒有用到分庫分表,怎么做的?

索引的常見實(shí)現(xiàn)方式有哪些,有哪些區(qū)別?MySQL的存儲引擎有哪些,有哪些區(qū)別?InnoDB使用的是什么方式實(shí)現(xiàn)索引,怎么實(shí)現(xiàn)的?說下聚簇索引和非聚簇索引的區(qū)別?

有沒有了解過協(xié)程?說下協(xié)程和線程的區(qū)別?

算法題一個(gè),劍指offer第51題,數(shù)組中的重復(fù)數(shù)字?

自己的回答情況,redis這塊沒啥問題,具體rehash有印象是漸進(jìn)式的,但是具體原理可能答的有點(diǎn)出入。tcp的time_wait這塊答的不是很好,之前沒有了解過quic機(jī)制的實(shí)現(xiàn),所以問可靠性udp的時(shí)候,基本上腦子里就照著tcp的實(shí)現(xiàn)在說。https這塊沒啥說的,之前項(xiàng)目里面有用到類似的東西,研究的比較清楚了。raft算法這個(gè)因?yàn)閯偤迷谒?.824(才刷到lab2。。。),答的也湊合,不過paxos和zab算法確實(shí)不熟悉,直接說不會。MySQL這塊很熟了,包括索引,鎖,事務(wù)機(jī)制以及mvcc等等,沒啥說的,都已經(jīng)補(bǔ)齊了。協(xié)程和線程,主要說了go程和Java線程的區(qū)別以及go程的調(diào)度模型。面試官提示沒有提到線程的有內(nèi)核態(tài)的切換,go程只在用戶態(tài)調(diào)度。最后一個(gè)算法題,首先說使用HashMap來做,說空間復(fù)雜度能不能降到O(1),后面想了大概5min才想出來原地置換的思路。

二面項(xiàng)目技術(shù)面

主要針對自己最熟悉的項(xiàng)目,畫出項(xiàng)目的架構(gòu)圖,主要的數(shù)據(jù)表結(jié)構(gòu),項(xiàng)目中使用到的技術(shù)點(diǎn),項(xiàng)目的總峰值qps,時(shí)延,以及有沒有分析過時(shí)延出現(xiàn)的耗時(shí)分別出現(xiàn)在什么地方,項(xiàng)目有啥改進(jìn)的地方?jīng)]有?

如果請求出現(xiàn)問題沒有響應(yīng),如何定位問題,說下思路?

tcp 粘包問題怎么處理?

問了下緩存更新的模式,以及會出現(xiàn)的問題和應(yīng)對思路?

除了公司項(xiàng)目之外,業(yè)務(wù)有沒有研究過知名項(xiàng)目或做出過貢獻(xiàn)?

基本都沒有啥問題,除了面試官說項(xiàng)目經(jīng)驗(yàn)稍弱之外,其余還不錯。

三面綜合技術(shù)

這面面的是陣腳大亂,面試官采用刨根問底的方式提問,終究是面試經(jīng)驗(yàn)不夠,導(dǎo)致面試的節(jié)奏有點(diǎn)亂。 舉個(gè)例子:

其中有個(gè)題是go程和線程有什么區(qū)別?

答:1 起一個(gè)go程大概只需要4kb的內(nèi)存,起一個(gè)Java線程需要1.5MB的內(nèi)存;go程的調(diào)度在用戶態(tài)非常輕量,Java線程的切換成本比較高。接著問為啥成本比較高?因?yàn)镴ava線程的調(diào)度需要在用戶態(tài)和內(nèi)核態(tài)切換所以成本高?為啥在用戶態(tài)和內(nèi)核態(tài)之間切換調(diào)度成本比較高?簡單說了下內(nèi)核態(tài)和用戶態(tài)的定義。接著問,還是沒有明白為啥成本高?心里瞬間崩潰,沒完沒了了呀,OS這塊依舊是痛呀,支支吾吾半天放棄了。

后面所有的提問都是這種模式,結(jié)果回答的節(jié)奏全無,感覺被套路了。大多度都能回答個(gè)一二甚至是一二三,但是再往后或者再深入的OS層面就GG了。

后面問了下項(xiàng)目過程中遇到的最大的挑戰(zhàn),以及時(shí)怎么解決的?

后面還問了一個(gè)問題定位的問題,服務(wù)器CPU 100%怎么定位?可能是由于平時(shí)定位業(yè)務(wù)問題的思維定勢,加之處于蒙蔽狀態(tài),隨口就是:先查看監(jiān)控面板看有無突發(fā)流量異常,接著查看業(yè)務(wù)日志是否有異常,針對CPU100%那個(gè)時(shí)間段,取一個(gè)典型業(yè)務(wù)流程的日志查看。最后才提到使用top命令來監(jiān)控看是哪個(gè)進(jìn)程占用到100%。果然陣腳大亂,張口就來,捂臉。。。

本來正確的思路應(yīng)該是先用top定位出問題的進(jìn)程,再用top定位到出問題的線程,再打印線程堆棧查看運(yùn)行情況,這個(gè)流程換平時(shí)肯定能答出來,但是,但是沒有但是。還是得好好總結(jié)。

最后問了一個(gè)系統(tǒng)設(shè)計(jì)題目(朋友圈的設(shè)計(jì)),白板上面畫出系統(tǒng)的架構(gòu)圖,主要的表結(jié)構(gòu)和講解主要的業(yè)務(wù)流程,如果用戶變多流量變大,架構(gòu)將怎么擴(kuò)展,怎樣應(yīng)對?

這個(gè)答的也有點(diǎn)亂,直接上來自顧自的用了一個(gè)通用的架構(gòu),感覺毫無亮點(diǎn)。后面反思應(yīng)該先定位業(yè)務(wù)的特點(diǎn),這個(gè)業(yè)務(wù)明顯是讀多寫少,然后和面試官溝通一期剛開始的方案的用戶量,性能要求,單機(jī)目標(biāo)qps是什么等等?在明確系統(tǒng)的特點(diǎn)和約束之后再來設(shè)計(jì),而不是一開始就是用典型互聯(lián)網(wǎng)的那種通用架構(gòu)自顧自己搞自己的方案。

3天后收到短信被拒

總結(jié)

tcp/udp,http和https還有網(wǎng)絡(luò)這塊(各種網(wǎng)絡(luò)模型,已經(jīng)select,poll和epoll)一定要非常熟悉

一定要有拿的出手的項(xiàng)目經(jīng)驗(yàn),而且要能夠講清楚,講清楚項(xiàng)目中取舍,設(shè)計(jì)模型和數(shù)據(jù)表

分布式要非常熟悉

常見問題定位一定要有思路

操作系統(tǒng),還是操作系統(tǒng),重要的事情說三遍

系統(tǒng)設(shè)計(jì),思路,思路,思路,一定要思路清晰,一定要總結(jié)下系統(tǒng)設(shè)計(jì)的流程

一點(diǎn)很重要的心得,平時(shí)blog和專欄看的再多,如果沒有自己的思考不過是過眼云煙,根本不會成為自己的東西,就像內(nèi)核態(tài)和用戶態(tài),平常也看過,但是沒細(xì)想,突然要自己說,還真說不出來,這就很尷尬了。勿以浮沙筑高臺,基礎(chǔ)這種東西還是需要時(shí)間去慢慢打牢,多去思考和總結(jié)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 工程師
    +關(guān)注

    關(guān)注

    59

    文章

    1571

    瀏覽量

    68574
  • JAVA
    +關(guān)注

    關(guān)注

    19

    文章

    2973

    瀏覽量

    104904
收藏 人收藏

    評論

    相關(guān)推薦

    面試題】人工智能工程師高頻面試題匯總:機(jī)器學(xué)習(xí)深化篇(題目+答案)

    隨著人工智能技術(shù)的突飛猛進(jìn),AI工程師成為了眾多求職者夢寐以求的職業(yè)。想要拿下這份工作,面試的時(shí)候得展示出你不僅技術(shù)過硬,還得能解決問題。所以,提前準(zhǔn)備一些面試常問的問題,比如機(jī)器學(xué)習(xí)的那些算法
    的頭像 發(fā)表于 12-16 13:42 ?2018次閱讀
    【<b class='flag-5'>面試</b>題】人工智能<b class='flag-5'>工程師</b>高頻<b class='flag-5'>面試</b>題匯總:機(jī)器學(xué)習(xí)深化篇(題目+答案)

    面試題】人工智能工程師高頻面試題匯總:Transformer篇(題目+答案)

    隨著人工智能技術(shù)的突飛猛進(jìn),AI工程師成為了眾多求職者夢寐以求的職業(yè)。想要拿下這份工作,面試的時(shí)候得展示出你不僅技術(shù)過硬,還得能解決問題。所以,提前準(zhǔn)備一些面試常問的問題,比如機(jī)器學(xué)習(xí)的那些算法
    的頭像 發(fā)表于 12-13 15:06 ?562次閱讀
    【<b class='flag-5'>面試</b>題】人工智能<b class='flag-5'>工程師</b>高頻<b class='flag-5'>面試</b>題匯總:Transformer篇(題目+答案)

    人工智能工程師高頻面試題匯總——機(jī)器學(xué)習(xí)篇

    隨著人工智能技術(shù)的突飛猛進(jìn),AI工程師成為了眾多求職者夢寐以求的職業(yè)。想要拿下這份工作,面試的時(shí)候得展示出你不僅技術(shù)過硬,還得能解決問題。所以,提前準(zhǔn)備一些面試常問的問題,比如機(jī)器學(xué)習(xí)的那些算法
    的頭像 發(fā)表于 12-04 17:00 ?927次閱讀
    人工智能<b class='flag-5'>工程師</b>高頻<b class='flag-5'>面試</b>題匯總——機(jī)器學(xué)習(xí)篇

    正是拼的年紀(jì)|65歲電子工程師上班VLOG #65歲退休 #電子工程師 #搞笑 #上班vlog

    電子工程師
    安泰小課堂
    發(fā)布于 :2024年07月25日 11:31:02

    用二創(chuàng),1:1復(fù)刻工程師的職場現(xiàn)狀

    工程師
    揚(yáng)興科技
    發(fā)布于 :2024年07月19日 18:30:07

    嵌入式軟件工程師和硬件工程師的區(qū)別?

    嵌入式軟件工程師和硬件工程師的區(qū)別? 嵌入式軟件工程師 嵌入式軟件工程師是軟件開發(fā)領(lǐng)域中的一種專業(yè)工程師,他們主要負(fù)責(zé)設(shè)計(jì)和開發(fā)嵌入式軟件,
    發(fā)表于 05-16 11:00

    大廠電子工程師常見面試題#電子工程師 #硬件工程師 #電路知識 #面試

    電子工程師電路
    安泰小課堂
    發(fā)布于 :2024年04月30日 17:33:15

    企業(yè)老工程師和高校老師有啥區(qū)別

    電子工程師硬件
    電子發(fā)燒友網(wǎng)官方
    發(fā)布于 :2024年02月28日 17:50:00

    java后端能轉(zhuǎn)鴻蒙app開發(fā)嗎

    java后端轉(zhuǎn)鴻蒙app開發(fā)好。 還是前端呢
    發(fā)表于 01-29 18:15