什么是全棧工程師
全棧工程師一詞,最早出現于Facebook工程師Calos Bueno的一篇文章 - Full Stack (需翻墻)。他把全棧工程師定義為對性能影響有著深入理解的技術通才。自那以后全棧這個詞便流行起來,我看到過的就有全棧工程師,全棧設計師,全棧運維,全棧市場營銷人員等等。而在“拉鉤”,“100Offer”等針對互聯網人才的招聘網站上,全棧工程師更是一躍成為熱門招聘職位,其薪資水平也比一般的開發工程師職位要高出一截。那么,什么是全棧工程師,我們又應該如何定義一名全棧工程師呢?
百度百科對全棧工程師的定義是這樣的:“掌握多種技能,并能利用多種技能獨立完成產品的人”。我覺得這個定義還不夠全面,我認為全棧工程師應該同時是一位資深開發工程師、架構師以及具有敏捷開發技能的程序員。全棧工程師對于軟件開發的認識往往已經進化了,他們把特定的技術拋到了身后,明白技術的更新始終比計算機理論要快的道理,因此,他們注重強化自身的核心技能,關注并樂于實踐其他技術。全棧工程師往往是某一方面的專家,同時通曉并善于在正確的場合運用其他語言、工具和技術。
全棧工程師的價值
隨著時間的推移,全棧工程師的作用和價值在越來越多的產品或項目中得到了印證。那么,我們來看看全棧工程師對于個人或公司意味著什么。
個人價值及自由度的極大提升 —— 我曾看過一些介紹全棧工程師的文章,文中大多強調了全棧工程師對于公司與團隊的價值。而我想說的是,沒有一個優秀的全棧工程師是因為會對公司產生多大的利益,而努力學習各種技術的。我所認識的他們,都是那些有著一顆匠心,不斷追求更高技能,并執著于做出更優秀產品的人。而當你成為一名真正的全棧工程師后,會感受到前所未有的個人價值與技術自由度的提升。試想當一個很好的創意出現時,你可以一個人或主導一個團隊去實現并不斷完善它,這是一件多么讓人興奮的事?。?/p>
全局思維與技術前瞻性 —— 由于具備了各個開發環節與技術領域的知識,全棧工程師往往具有更好的大局觀和技術前瞻性,能夠在項目初期就選擇正確的技術,并很好地把控一個項目的整體方向?,F代項目往往非常復雜,而全棧工程師往往能帶來技術和質量上的保障,從而成為一個項目成功的關鍵人物。
降低溝通成本 —— 我經常聽到有設計師抱怨前端工程師無法百分之百地還原他們的設計,而前端工程師又在抱怨后端工程師從接口返回的數據更本無法直接使用,后端工程師也在抱怨產品經理所提的需求根本無法完成。隨著團隊人數的上升,由于各自技能棧的不同,溝通成本一定會隨之上升。全棧工程師除了能夠獨立完成前后端的開發(甚至包括設計)外,如果能夠在項目初期提前介入,便能很好地規避技術風險,過濾不合理的需求,從而顯著降低因不同技術差異導致的溝通問題,顯著降低項目風險。
初創公司 —— 我們已經來到了一個萬眾創業,全民創新的時代。那些初創公司也如雨后春筍般不斷涌現。初創公司往往都有了一個不錯的創意,但經常會遇到“就缺一個程序員”的尷尬。我想說的是,他們其實并不是缺程序員,而是缺一位全棧工程師。初創公司往往資金有限,而一名優秀的全棧工程師能夠幫助初創公司用最低的代價與最短的時間推出自己的產品。這是初創公司能夠存活下來,拿到更多投資,甚至成為“獨角獸”一員的最關鍵一步。
全棧工程師的技能棧
看到這里你一定會問,到底需要具備怎樣的技能才能成為一名全棧工程呢?下面這張圖來自Medium,作者將軟件開發所涉及的各個方面分為層,又將每個層所包含的主要技術作為組件,制作了這張全棧技術圖。
從上面這張圖,我們不難發現,現在的技術體系是多么龐大,每一年又會有新的技術加入到這些層中,而已有的技術又在不斷地更新。因此要掌握所有技術是根本不可能的,而成為全棧工程師也并不需要你真的掌握所有的技術,你應該將自己的精力聚焦于關鍵開發技能以及一些必須掌握的附加技能上。
關鍵開發技能(硬實力):
**Git / GitHub **—— 你必須掌握如何使用Git來管理和分享你的代碼。把Git作為關鍵技能的第一條,是因為它不僅僅是一個代碼管理工具,更是一種推薦的工作方式。它使你能在任何地方進行開發,高效地管理任何大小的項目,通過Git你還能與其他團隊成員進行分布式協作,大大提升工作效率。通過GitHub,還能將你與世界所有的開發者聯系在一起。
至少一門編程語言 —— 你需要精通至少一門編程語言,JAVA 、PHP、C#、Python、Ruby、Perl 等,因為你的大多數核心業務處理都需要用這門語言來寫。你既要掌握這門語言的語法,又需要非常熟悉如何基于這門語言進行項目的架構、設計、實現以及測試。如果你選擇的是JAVA,那么你就需要掌握面向對象的設計和開發,設計模式的應用,基于J2EE各個組件的開發 等等。
運用開發框架和第三方庫 —— 流行的開發語言,一般都伴有出色的開發框架,比如JAVA的Spring、MyBatis、Hibernate,Python的Django,PHP的 thinkphp、yin,nodeJs的 express 等等。這些開發框架往往都遵循軟件開發領域的一些最佳實踐,并由非常優秀的開發人員創建。熟練使用這些開發框架或第三方庫能夠避免重復發明輪子,使你的工作事半功倍。更重要的是這些優秀框架或第三方庫的一般都得到持續的維護,是對你的產品或項目在質量與安全方便的最有效的保障。
前端技術 —— 之所以將前端技術獨立出來,作為一項關鍵技術,是因為它在今天的項目和產品的研發過程中正變得越來越重要。一個產品除了實現所需的功能之外,是否好用(用戶體驗)也正在成為評判一個產品是否成功的重要標準。而這都依賴于前端技術的實現,你至少需要掌握 HTML5、CSS3、JavaScript 等基本前端技術,同時進一步學習 JQuery、LESS、SASS、AngularJS或REACT等前端框架或第三方庫。
數據庫與緩存 —— 任何產品或項目都需要一個數據庫來存儲數據。作為全棧工程師,你也需要至少掌握一到兩個數據庫,并知道怎樣與數據庫進行交互。目前流行的數據庫主要有MySQL、MongoDB、Redis、Oracle、SQLServer等。MongoDB作為文檔型數據庫,在互聯網產品中正被越來越多地使用,對于規模稍大一些的項目,我仍推薦使用MySQL或商用的Oracle作為后端數據庫。而Redis這樣的內存數據庫則可以用于緩存,以提升系統的性能。
基本設計能力 —— 大部分關于全棧工程師的文章或討論中,都不會將設計能力做為全棧工程師的關鍵技能,但我卻認為這項技能非常重要。我曾被邀請評估一些軟件工程師自己開發的產品,這些產品都有不錯的創意,功能實現也很到位,但一看就不是一個好的產品,用戶根本沒有使用欲望,原因是這些產品的設計太差了,而往往那些開發者完全沒有意識到問題的存在,比如色彩的不一致,排版的凌亂,不恰當的圖標 等等。我所建議的基本設計能力,并不要求你像專業設計師那樣能夠P出神圖、制作奇妙的視覺效果等,但你需要掌握最基本的UI設計原則,如 色彩的搭配,基本的排版,并具備良好的審美能力,和一些基本UI設計能力,這樣你做的產品就不會太差了。
在掌握了這些核心技能之后,你可以根據自己的興趣與發展方向,學習其他方面的技術。比如,如果你對數據處理感興趣,那么你可以學習大數據方面的技術。如果你對移動互聯網更感興趣,那么你可以學習Swift,開發ios應用。知識總是相通的,在有了良好的技術基礎后,學習其他知識將會變得非常容易。
附加技能(軟實力):
溝通 —— 除非你是在做個人項目,對于稍大一些的項目,你總是需要與同事、干系人或是客戶進行溝通的。而成功的溝通往往是獲得有效需求,與建立團隊信心的第一步。在項目的進行過程中,你更需要通過有效的溝通去確定方案,消除誤解,與項目成員協同前進。良好的溝通能力將使你在團隊中更具影響力,收到更多尊重和關注。
問題解決能力 —— 全棧工程師首先是一名工程師,他必須掌握工程化的方法來解決遇到的各種問題。我在職業生涯中的幾乎所有亮點,都與解決問題相關,大到提供整個項目的架構方案,小到以最快的速度解決生產問題 等。其實有很多提高問題解決能力的方法,但沒有一種比實踐更有效。我所見到的優秀工程師,往往能夠憑借直覺以最短的時間給出正確的解決方案,但你可能沒有看到的是,在這背后其實是經過大量實踐累積而來的經驗。
時間管理 —— 作為全棧工程師,你可能會被安排同時在不同的項目中承擔不同的角色。你需要合理地分配時間,保證所有的工作能夠按時交付。同樣在你的業余時間,你還需要花時間閱讀和學習,同時你還可能會有自己的Side Project。因此,合理地進行時間分配,并對一些關鍵任務,進行計劃是很重要的。你或許會感到一些壓力,但這反而會激發你的創造力,并能讓一切都有條不紊地進行。
好奇心 —— 對任何工作都抱有好奇心,并愿意不斷學習和改善是那些優秀工程師的共同特性。軟件開發領域匯集了世界上最聰明的人,各種類型的技術、產品、框架更是日新月異,層出不窮。優秀的全棧工程師需要不斷地學習來抓住這些變化,跟上計算機領域發展的腳步。時常有人會問我,做計算機這一行一直會有新的東西產生,要去不斷地學習,是不是會很累。我要說的是,對于將持續學習作為一種生活習慣的人來說,學習新東西并不會成為一種負擔,反而是一種樂趣。
領導力 —— 優秀的全棧工程師往往會被賦予技術Leader甚至項目管理者的角色。成為管理者并不是讓你去支配其他人,或讓其他人替你做事。管理者需要理解你的團隊成員的長處與不足,并知道如何以服務的態度使團隊獲得最大化的產出。我見過一些非常優秀的工程師,當他們被安排去管理團隊時,他們是排斥的,他們往往更愿意獨自工作。但我想說,成為管理者,將會使你更加睿智、可靠和值得他人信賴,也會對你未來的職業生涯帶來極大的益處。因此,當機會到來時,請將它視為挑戰,不要排斥它。
有經驗的技術領導者在招聘時,往往會同時考察應聘者技術能力與上述附加技能,而對于初級程序員的招聘來說,那些附加技能往往更被優秀的技術公司所看重。開發技能是你的硬實力,而附加技能則可以看作是你的軟實力,只有同時具備這兩方面技能,才能成為一名優秀的全棧工程師。
優秀的全棧工程師需要走出去
優秀的全棧工程師不應局限于自己的工作,他更應該走出去,接觸不同的技術,分享自己的經驗和心得,認識更多的朋友。下面便是我的一些做法。
參加技術大會 —— InfoQ、CSDN、GITC、優設、TED 等網站都會定期舉辦各類技術大會。在這些大會上,你不僅能夠聽到技術大咖們帶來的各自領域最佳技術實踐,而且能認識很多行業內的朋友。這對你開拓思路,擴大技術社交圈都很有幫助。因此,如果公司沒有安排你去參加這些技術大會的話,那就自己買票參加,作為對自己的一種投資吧。
作公開演講 —— 全棧工程師并不需要是一個公開演講者,但作為團隊的核心成員,他一定需要在團隊內部做技術、管理等方面的進行演講。如果你是一個樂于分享的技術達人,那么也可以嘗試錄制個人課程(視頻或音頻),并在慕課、網易課堂、優酷 或 像 荔枝、喜馬拉雅 等各種媒體分享自己的技能和知識,不要因為自己并不是專家就不愿嘗試,相信我,你用心制作的內容,會獲得大家的認可,并收獲一大批粉絲的。
個人博客 —— 每天進步一點點,一年以后你便會獲得質的飛躍。優秀的全棧工程師懂得如何進行知識的積累,而技術博客就是一個很好的方式,將自己平時的實踐、思考記錄下來,配以tag標簽方便日后的回顧。最有意思的是,當你在不斷記錄和更新你的博客同時,世界各地的程序員也會通過你的博客認識你。
參加線下活動 —— 與以前程序員總是宅在家里不同,現在的年輕程序員們更愿意分享和交流。很多網站也會組織不同技術主題的線下活動,在這些活動中你可以聽到一些技術牛人的分享,還可以找到很多和你一樣對技術富有激情的人。而我現在所做的開源項目中的很多團隊成員,正是我在這些線下活動中結識的。
全棧工程師決不是一夜練成的,你需要打好技術基礎,強化核心技能,并持續學習。相信有一天你也能像我一樣,感受到自由地運用技術,開發出優秀產品所帶來的樂趣的。
-
工程師
+關注
關注
59文章
1571瀏覽量
68560
發布評論請先 登錄
相關推薦
評論