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