整懵了,蚂蚁金服6面成功拿下offer涨薪15K,突然觉得跳槽也不是那么难
螞蟻的面試挺獨特,每輪面試都沒有 HR 約時間,一般是晚上 8 點左右面試官來一個電話,問是否能面試,能的話開始面,不能就約一個其它時間。
全程 6 面,前五面技術(shù)面,電話面試,最后一面是 HR 面,現(xiàn)場面。 大佬說技術(shù)這方面肯定要掌握好,其實面試題也可以背一背,要是他提前有時間就看一下面試題說不定有些問題就可以回答得更好,可以起個抱佛腳的作用。
注:這邊整理了最新最全——Java一線大廠面試題解析合集:JAVA基礎(chǔ)-中級-高級面試+SSM框架+分布式+性能調(diào)優(yōu)+微服務(wù)+并發(fā)編程+網(wǎng)絡(luò)+設(shè)計模式+數(shù)據(jù)結(jié)構(gòu)與算法!- 第一部分:Java基礎(chǔ)-中級-高級
?
- 第二部分:開源框架(SSM:Spring+SpringMVC+MyBatis)
?
- 第三部分:性能調(diào)優(yōu)(JVM+MySQL+Tomcat)
?
- 第四部分:分布式(限流:ZK+Nginx;緩存:Redis+MongoDB+Memcached;通訊:MQ+kafka)
?
- 第五部分:微服務(wù)(SpringBoot+SpringCloud+Dubbo)
?
- 第六部分:其他:并發(fā)編程+設(shè)計模式+數(shù)據(jù)結(jié)構(gòu)與算法+網(wǎng)絡(luò)
?
一面
- 介紹一下自己
- 問項目經(jīng)歷, 聊"數(shù)據(jù)同步"
- 接著聊上了 K8S 的項目
- 有沒有什么鉆研得比較深得技術(shù)?(大佬:kubernetes, golang, prometheus, java)
- kubernetes 的架構(gòu)是怎么樣的?
- 這個問題很大,拆成 apiserver、controller、kubelet、scheduler 講了一下
- golang 與 java 的比較
- 這個問題又很大,當(dāng)時主要對比了 vm、協(xié)程支持、面向?qū)ο蠛头盒偷膮^(qū)別、以及自己對各自使用場景的一些理解
- golang 的 gc 算法
- 知道是三色標(biāo)記,不過細節(jié)說不上來
- 從無限的字符流中, 隨機選出 10 個字符
- 沒見過也沒想出來,查了一下是蓄水池采樣算法,經(jīng)典面試題,沒刷題吃虧了
- 怎么擴展 kubernetes scheduler, 讓它能 handle 大規(guī)模的節(jié)點調(diào)度
- 單節(jié)點提速:優(yōu)選階段隨機取部分節(jié)點進行優(yōu)選;水平擴展 scheduler 節(jié)點,pod 做一致性 hash 來決定由哪個scheduler 調(diào)度
- 你有什么想問我的?
一面其實有點僵,大佬自己完全沒放開,面試官對大佬的回答沒有什么反饋和深入,都是"哦好的"然后就過了。所以大佬當(dāng)時面完覺得自己其實已經(jīng)掛了(要是對候選人不感興趣,有時候也就問完問題走個過場溜了),后來收到二面電話著實吃驚了一下。
二面
- 先聊了聊項目
- 給 Prometheus 做了哪些改動?
- 自研配置中心, 具體做了哪些內(nèi)容?
- 有用過 MySQL 的什么高級特性嗎?
- 這里不太理解,我問什么算高級特性,面試官就切換到了下一個問題
- 配置中心的核心數(shù)據(jù)表是怎么設(shè)計的?
- 為什么在業(yè)務(wù)里用 Redis, Redis 有什么優(yōu)點?
- 單線程:并發(fā)安全;高性能;原語與數(shù)據(jù)結(jié)構(gòu)豐富;采用廣泛,踩坑成本低
- 對 Redis 里數(shù)據(jù)結(jié)構(gòu)的實現(xiàn)熟悉嗎?
- 說了一個 zset 跳表
- 用過 Redis 的哪些數(shù)據(jù)結(jié)構(gòu), 分別用在什么場景?
- Java 初始化一個線程池有哪些參數(shù)可以配置, 分別是什么作用?
- 自己寫的 Java 應(yīng)用調(diào)優(yōu)過哪些 JVM 參數(shù), 為什么這么調(diào)優(yōu)?(這個問住了,大佬只知道最大堆最小堆,開 G1,開 GC 日志以及 OOM dumper 這些基本的)
- 用 Jetty 的時候有沒有配什么參數(shù), 為什么這么配?
- Jetty QTP 等待隊列配置成無限的話, 你覺得好嗎? 會有什么問題嗎?
- 用過 Linux Bash 里的哪些命令, 分別用它們干嘛?
- 一道筆試題: 需要在給的鏈接中作答, 不能 google, 不能跳出, 不能用 IDE:
題目是這樣的:
啟動兩個線程, 一個輸出 1,3,5,7…99, 另一個輸出 2,4,6,8…100 最后 STDOUT 中按序輸出 1,2,3,4,5…100
大佬:用 Go 實現(xiàn)吧 面試官:不可以,用 Java 的 notify 機制實現(xiàn) 大佬::(還沒意識到問題的嚴(yán)峻) 那用 Java BlockingQueue 面試官:說不可以, 要求用 Java 的 wait + notify 機制來實現(xiàn)
因為完全沒寫過 wait + notify,只能表示不會, 面試官說那行吧你可以用 go 寫
最后用 go channel 實現(xiàn)了一版, 不過給的網(wǎng)頁上不能運行代碼,也不知道寫得對不對,然后面試結(jié)束。
這一輪面試官延續(xù)了一面的風(fēng)格,問完一題就趕忙下一題了,似乎沒有表現(xiàn)出對我的回答有興趣或認可。因此這輪面完,他覺得自己可能又掛了…
三面
- 依然先聊項目
- 對監(jiān)控警報的項目很感興趣, 問了挺多細節(jié),。最后問了一個問題::現(xiàn)在要你實現(xiàn)一個語義不弱于 PromQL 的查詢語言, 你能實現(xiàn)嗎?(這里雖然看過一些 Prometheus 的代碼,但其實對 PromQL 的 lexer 和 parser 部分沒有細看,還好之前因為數(shù)據(jù)同步項目里想寫聲明式 Stream SQL 研究過一點 ANTLR,用 ANTLR 寫語法 + AST 遍歷塞查詢邏輯給糊弄過去了。)
- 覺得做得最深入的項目是什么(當(dāng)然是數(shù)據(jù)同步)
- 聊數(shù)據(jù)同步項目
- 問 Linux 掌握得怎么樣?(沒有系統(tǒng)學(xué)習(xí)過,基本上是自己運維踩坑積累的)
- 問 Golang 掌握得怎么樣?(用了半年, 看過 effective go)
- 問算法掌握得怎么樣?(到圖為止都可以)
- 問最短路算法(只記得 dijkstra 了,描述了代碼流程)
- k8s 掌握得怎么樣?(沒有自己寫過 controller 和 scheduler,但是對概念都很熟悉,看過 xxx 這幾部分的源碼)
- k8s 的 exec 是怎么實現(xiàn)的?(這個問題正中下懷,之前寫了 PingCAP 的小作業(yè)正好對這塊特別熟悉)
這輪聊得順暢多了。同時發(fā)現(xiàn)螞蟻的面試官似乎挺喜歡讓你自己評價:“你覺得自己 xxx 掌握得怎么樣?”(只有五位面試官,樣本不夠大,不能作數(shù)哦),這類問題其實我慌得要死,怕吹過頭了答不上來,面試掛了事小,丟了面子事大。早知道就預(yù)習(xí)一下怎么吹噓了。
四面
- 介紹一下自己
- 覺得自己基礎(chǔ)知識掌握怎么樣
- 平時一般會用到哪些數(shù)據(jù)結(jié)構(gòu)?
- 鏈表和數(shù)組相比, 有什么優(yōu)劣?
- 如何判斷兩個無環(huán)單鏈表有沒有交叉點
- 如何判斷兩個有環(huán)單鏈表有沒有交叉點
- 如何判斷一個單鏈表有沒有環(huán), 并找出入環(huán)點
- TCP 和 UDP 有什么區(qū)別?
- 描述一下 TCP 四次揮手的過程中
- TCP 有哪些狀態(tài)
- TCP 的 LISTEN 狀態(tài)是什么
- TCP 的 CLOSE_WAIT 狀態(tài)是什么
- 建立一個 socket 連接要經(jīng)過哪些步驟
- 常見的 HTTP 狀態(tài)碼有哪些
- 301和302有什么區(qū)別
- 504和500有什么區(qū)別
- HTTPS 和 HTTP 有什么區(qū)別
- 寫一個算法題: 手寫快排
這一輪全程問的基礎(chǔ)知識,基礎(chǔ)扎實的話就沒問題了,不過大佬感覺有一點像校招的問法。
五面
- 介紹一下自己
- 在 k8s 上做過哪些二次開發(fā)?
- 自己用 Helm 構(gòu)建過 chart 嗎?有哪些?
- 有沒有考慮過自己封裝一個面向研發(fā)的 PaaS 平臺?
- 配置中心做了什么?
- 為什么不用 zookeeper?
- 配置中心如何保證一致性?
- Spring 里用了單例 Bean, 怎么保證訪問 Bean 字段時的并發(fā)安全?
- 用并發(fā)安全的數(shù)據(jù)結(jié)構(gòu),比如 ConcurrentHashMap;或者加互斥鎖
- 假如我還想隔離兩個線程的數(shù)據(jù), 怎么辦?
- ThreadLocal,然后舉了個例子
- Golang 里的逃逸分析是什么?怎么避免內(nèi)存逃逸?
- 這個不知道,認慫了
- 對比一下 Golang 和 Java 的 GC
- 答了一下 CMS、G1和三色標(biāo)記,我對比的點是 JVM 有分代回收,Go 的 Runtime 沒有,沒能深入地講
- Golang 的 GC 觸發(fā)時機是什么
- 閾值觸發(fā);主動觸發(fā);兩分鐘定時觸發(fā);
- 有沒有寫過 k8s 的 Operator 或 Controller?(大佬:沒有寫過)
- 談一談你對微服務(wù)架構(gòu)的理解
- 大體思路"微服務(wù)本質(zhì)是人員組織架構(gòu)演進與關(guān)注點分離"
- 談一談你對 Serveless 的理解
- 大體思路"Serveless 是繼 docker 與容器編排之后的又一次應(yīng)用開發(fā)與基礎(chǔ)設(shè)施提供方之間的邊界劃分"
- 你認為 Serveless 是未來嗎? 為什么?
- 大體思路"是云服務(wù)的未來,把蛋糕從企業(yè)的IT、運維與中間件部門切走,形成規(guī)模效應(yīng),做得越多賺得越多;公司內(nèi)的話 servless能夠幫助加速前臺業(yè)務(wù)迭代,但對中后臺的收益還看不到,未來可能會有比 servless 更適合中后臺的架構(gòu)"
面試官:最后你有什么要問我的?
大佬:為什么足足安排了五輪技術(shù)面,而且其中有兩輪似乎和 k8s 沒有關(guān)系啊?
面試官:我們覺得你做過的東西挺多的,各個方向都想讓你嘗試一下
我:那這輪是最后一輪技術(shù)面嗎?
面試官:不一定
后續(xù)還問了面試官一些業(yè)務(wù)相關(guān)的問題,就不贅述了
五面最后的三個吹水問題大佬說還挺感興趣,可惜面試官只是聽他講,沒有跟他討論。還有就是問了面試官才知道,二面四面的面試官是 PaaS 平臺那邊的,因此主要問 Java 沒有涉及到 k8s 和 go。
六面(HR 面)
之前聽說過阿里系的 HR 是來"聞味道的"(看你是否適合阿里的風(fēng)格),而且有一票否決權(quán)。所以還是挺有壓力的。
- 問經(jīng)歷
- 為什么要考慮出來看看呢?
- 金句:“現(xiàn)在自己的技術(shù)成長有點碰到瓶頸,加上一直對您公司欽慕有加relaxed”"
- 現(xiàn)在公司的主營業(yè)務(wù)是什么?(這塊往技術(shù)上問了很多,感覺是想考察我解釋復(fù)雜問題的能力)
- 現(xiàn)在帶人嗎?report 層級是怎樣的?
- 對自己這幾年的經(jīng)歷滿意嗎?
- 覺得自己有什么缺點?
- 碰到過什么很挫敗的事情嗎?
- 未來的職業(yè)規(guī)劃是怎樣的?
- 看機會的時候,主要考慮的是待遇、平臺、人員還是什么其他因素?
- 現(xiàn)在的待遇如何
- 有什么想問我的?
整體聊了 40 多分鐘,話題挺廣的,面試官也說了系統(tǒng)部這邊壓力挺大的,優(yōu)秀的人才才能留下來。
大佬覺得 HR 面里除了談薪酬的部分沒有什么可準(zhǔn)備的,想說什么直說就行。因為到了 HR 面至少證明你的技術(shù)沒什么問題,直說出來方便 HR 判斷兩邊的價值觀是否合拍,假如真的不合拍,那其實在 HR 這一面掛了比起進去之后再后悔又跳槽要好很多,畢竟大家都不喜歡頻繁跳槽的簡歷。
小結(jié)
完事后問了一些主觀評價:
- 面試難度:正常
- 面試體驗:還不錯,感覺沒這么難。(反正我是酸了)
- 問題偏向:基礎(chǔ)知識,開發(fā)常識,技術(shù)見解
螞蟻的面試風(fēng)格比較"高冷",面試官給大佬的一致感受就是很強,臥虎藏龍。面試內(nèi)容上在基礎(chǔ)知識部分相對考察得多一些,沒有偏門和獵奇的問題,基礎(chǔ)知識扎實的同學(xué)可以大膽投投看螞蟻。
最后提供Java架構(gòu)學(xué)習(xí)資料,包含有:架構(gòu)筑基、開源框架、分布式、微服務(wù)、高并發(fā)、網(wǎng)絡(luò)等等資料獲取:私信 面試資料 即可打包帶走哦!
- Java架構(gòu)進階之架構(gòu)筑基篇(Java基礎(chǔ)+并發(fā)編程+JVM+MySQL+Tomcat+網(wǎng)絡(luò)+數(shù)據(jù)結(jié)構(gòu)與算法)
- Java架構(gòu)進階之開源框架篇(設(shè)計模式+Spring+SpringMVC+MyBatis)
- Java架構(gòu)進階之分布式架構(gòu)篇 (限流(ZK/Nginx)+緩存(Redis/MongoDB/Memcached)+通訊(MQ/kafka))
- Java架構(gòu)進階之微服務(wù)架構(gòu)篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)
總結(jié)
以上是生活随笔為你收集整理的整懵了,蚂蚁金服6面成功拿下offer涨薪15K,突然觉得跳槽也不是那么难的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: bug:生产问题,Golang解决csv
- 下一篇: 从Scanpy的Anndata对象提取信
