1. 程式人生 > >如何面試Python後端工程師?

如何面試Python後端工程師?

吃午飯的時候我就一直在想這個問題,我覺得重點不是Python而是後端工程師,因為Python只是系統的一部分,linux基礎操作要熟吧,sql要懂吧,訊息佇列要知道吧,git要熟悉吧……木桶理論,每一環都不能落下,精通其中一兩環就更好了。基礎功紮實,新東西學得快,程式碼寫得溜,命令敲得順,bug解的好,媽媽再也不用擔心我天天加班了~~~

一.語言 1.推薦一本看過最好的python書籍? 拉開話題好扯淡 2.談談python的裝飾器,迭代器,yield? 3.標準庫執行緒安全的佇列是哪一個?不安全的是哪一個?logging是執行緒安全的嗎? 4.python適合的場景有哪些?當遇到計算密集型任務怎麼辦? 5.python高併發解決方案?我希望聽到twisted->tornado->gevent,能扯到golang,erlang更好

二.作業系統 可以直接認為是linux,畢竟搞後端的多數是和linux打交道。 1.tcp/udp的區別?tcp粘包是怎麼回事,如何處理?udp有粘包嗎? 2.time_wait是什麼情況?出現過多的close_wait可能是什麼原因? 3.epoll,select的區別?邊緣觸發,水平觸發區別?

三.儲存 儲存可能包含rdbms,nosql以及快取等,我以mysql,redis舉例 mysql相關 1.談談mysql字符集和排序規則? 2.varchar與char的區別是什麼?大小限制?utf8字符集下varchar最多能存多少個字元 3.primary key和unique的區別? 4.外來鍵有什麼用,是否該用外來鍵?外來鍵一定需要索引嗎? 5.myisam與innodb的區別?innodb的兩階段鎖定協議是什麼情況? 6.索引有什麼用,大致原理是什麼?設計索引有什麼注意點? redis相關 1.什麼場景用redis,為什麼mysql不適合? 2.談談redis的事務?用事務模擬原子+1操作?原子操作還有其它解決方案嗎? 3.redis記憶體滿了會怎麼樣?

四.安全 web安全相關 1.sql注入是怎麼產生的,如何防止? 2.xss如何預防?htmlescape後能否避免xss? 3.csrf是什麼?django是如何防範的?

密碼技術 1.什麼是分組加密?加密模式有哪些?ecb和cbc模式有什麼區別?為什麼需要iv向量? 2.簡單說說https的過程? 3.對稱加密與非對稱加密區別? 3.如何生成共享祕鑰? 如何防範中間人攻擊?

五.雜 是否關注新技術啊?golang,rust是否瞭解?numpy,pandas是啥鳥? 是否緊跟時代潮流?逛不逛微博,刷不刷知乎?

可能你覺得我問的好細,但這好多都是平常經常遇到,並需要解決的,細節更能體現一個人。

如果你覺得小kiss,歡迎投簡歷給我[email protected],龍圖遊戲運營支援中心資料分析部招人;覺得有點問題,那還等什麼,趕快來和我交流交流。

更新:討論區挺熱鬧,有人說好簡單,有人說好難,其實我覺得這隻適合面試2~3年工作經驗的後端工程師。真的沒有問 很難的題目,只是可能你平時沒有注意。 在這裡我推薦幾本書吧 python參考手冊,絕對讓你更上一層樓 圖解密碼技術,密碼入門不二之選 mysql技術內幕第五版,有點厚當手冊讀讀,要有耐心,高效能mysql也強烈建議讀讀 effective tcp/ip programming

為什麼評論區有這麼大差異?我想是個人經歷不一樣吧,如果是搞web的對作業系統這塊和密碼技術會偏弱,但如果是系統工程師或是遊戲服務端這塊會明顯偏強。

六.後記 最近我也面試了不少童鞋,我發現能達到要求的真的少之又少,很多hr都說Python是最難招聘的崗位,我想是有道理的,這真的很值得我們去深思?

我想有一部分原因是Python這門語言造成的,會寫Python的人很多,但寫的好的人很少,大部分都把Python當做指令碼來寫,缺乏面向物件,模式的思想。想想Java,大家都習慣了介面,實現分離,設計模式在Java中也喊了很多年,尤其是ssh三大框架一出,用著用著就理所當然的認為就該這麼做,雖然也有點壞處,但對企業級Java開發無疑是一大進步。

反觀Python,尤其是生成器,協程,元類給Python注入了很大的靈活性,想寫的Pythonic有不小難度,但其實Python高階特性就那麼幾個,幹掉了也就沒有了。

當你覺得Python遇到了瓶頸,不妨停下來好好想想。研究研究設計模式,想想重構,瞭解領域驅動設計,敏捷開發,再回來讀讀以前寫的程式碼,當眼界變高了,程式碼也就美了。

當然思想的提高不是一朝一夕,模式,原則會經常讓你糾結,糾結就會思索,思考就走出了自己的路,當然條條大路通羅馬。

資料庫等儲存技術是研發工程師邁不過的坎,對關係資料庫以mysql舉例來說,你必須清楚的知道什麼欄位選擇什麼型別,型別位元組大小,限制條件,這東西也很容易理解,多想想即可,比如set型別,要支援交併等操作,1個位元組只能存8個類別。資料型別搞定了,下面就是索引了,mysql索引種類?主鍵,唯一索引,普通索引。索引類別,BTree索引,hash索引。索引的優缺點,mysql的索引查詢原理,join原理(大部分都是nested loop),以及一些特殊的情況,比如mysql子查詢慢等。其實到這裡研發工程師就差不多,當然你可以繼續深入下去,比如讀寫分離,叢集管理,甚至一些引數調優。 革命尚未成功,同志任需努力!!!!