最近網上在熱烈討論一則傳聞,說Facebook在招聘所謂的“全棧工程師”(Full Stack Engineer),要求應征者對開發堆棧的每個方面都有所掌握。那究竟何為 “全棧工程師”呢?從字面上來理解,全棧工程師必須熟悉開發堆棧的每一個層次,或者至少熟悉絕大多數并且對所有的軟件技術有天生的熱情和興趣。
對于這樣的開發者,他們非常擅長使用掌握的技術讓自己的生活變得輕松,這也正是為什么Facebook會希望雇傭他們,他們用自己的腦子與熱情編碼, 好的產品也自然能在最短的時間呈現。那么,具體而言,一個合格的“全棧工程師”要具備哪些素質呢?
開發堆棧剖析
服務器,網絡以及宿主環境
需要理解哪些模塊可能失效以及為什么,而不能理所當然地認為,只要不斷增加資源就能解決所有問題。
知道如何運用操作系統、云存儲、網絡資源,并能理解數據冗余以及可用性是必需的。
了解應用的規模是如何對硬件造成限制的。
還有多線程和競態條件,這些概念在開發機上往往不會遇到,但是他們在現實的部署環境中卻無處不在。
全棧工程師還必須要能夠與DevOps很好地協作。他們所設計的系統應該提供有用的錯誤消息和日 志能力,這樣DevOps就能夠及時獲得這些信息,并采取有價值的行動。
數據建模
如果數據模型存在缺陷,那么就常常需要在業務邏輯和更高的層面上使用丑陋的代碼來彌補那些數據模型沒辦法覆蓋的死角。
知道如何建立合理的范式關系模型,具備完善的外鍵、索引、視圖、查詢表等等。
還要熟悉非關系型數據的存儲,知道非關系型數據庫在哪些方面超越關系型數據庫。
業務邏輯
這是系統應用價值的關鍵所在。
掌握SOLID設計能力(單一職責,開放且封閉,Liskov替代性,接口分離,依賴注入)。
熟悉一些常用的框架。
API/Action/MVC
這些關乎外部世界如何與業務邏輯及數據模型交互。
會使用到大量的框架。
有能力寫出清晰、一致、使用簡單的接口。
用戶界面
全棧工程師需要:a)懂得如何構建易讀的布局;b)能意識到藝術家和圖形設計師的作用。總之,實現一套好的視覺設計方案尤為關鍵。
熟練掌握HTML5/CSS。
從目前的趨勢來看,JavaScript將會是明日之星,最近這一領域碩果累累(NodeJs, backbone, knockout, Angular(自己的加的, 原文沒有))。因此,掌握JavaScript必不可少。
用戶體驗
全棧工程師應該意識到:用戶僅僅是希望一切運轉良好。
一個好的系統是不會讓用戶得腕管綜合征或產生眼疲勞的。全棧工程師能審視全局,可以將一個需要8次點擊+3個步驟的過程,簡化為僅需要一次點擊。
知道如何向用戶提示錯誤信息。如果出現故障,真誠道歉。有時一些無意的錯誤信息,會讓用戶感到莫名奇妙。
理解用戶和市場需求
這層關系到系統架構,但也絕不是一個不能碰的角色(有可能翻譯有誤,原文:but that is too much of a hands off role)。
全棧工程師要領悟客戶使用軟件過程中會需要些什么以及整個市場需要些什么。
其他方面
能寫出高質量的單元測試,時至今日,甚至連JavaScript都能寫出單元測試了。
知道如何使用可重復的自動化工具來構建系統、測試、撰寫文檔以及按需部署。
系統的安全意識非常重要,要知道,開發堆棧中的每一層都可能存在薄弱環節。
總結
將代碼與某個特定的實現(無論是軟件庫,操作系統,硬件,等等)緊綁在一起并不是好的實踐。全棧工程師雖然學術淵博,但不意味著他們能抄 捷徑,除非他們是在開發一個建完即扔的一次性原型。
技術型的創業企業在初期為了滿足靈活性,對全棧工程師的需求比較大,但是,隨著企業的成熟,會需要越來越多的專業型人才。
要成為一名全棧工程師,至少要使用過多種編程語言在各種領域的不同平臺工作多年。全棧工程師除了像“高級工程師”那樣要掌握多門編程語言, 還必須具有更高的視野將所有的模塊聯系起來。值得注意的是,在以上列表中,僅有3——5項是與編碼有關的。
-
工程師
+關注
關注
59文章
1570瀏覽量
68515 -
Facebook
+關注
關注
3文章
1429瀏覽量
54741
發布評論請先 登錄
相關推薦
評論