App下載

為什么CTO、技術總監(jiān)、架構師都不寫代碼,還這么厲害?

猿友 2021-03-01 17:31:14 瀏覽數 (8709)
反饋

常常會被問到這樣的問題:CTO、技術總監(jiān)、架構師很少寫具體代碼,為什么還很牛逼的樣子,拿這么高工資?

其實,這個問題本身就錯了。就好比問:導演、制片人為什么不懂演戲,還能指導演員,好像比演員厲害似的?其實不難理解,導演、制片人的核心能力并不是演戲,又怎么能跟演員作比較呢?

回答前面的問題,邏輯也是一樣的,拿 CTO、技術總監(jiān)、架構師,跟程序員比寫代碼的能力,本身就是個錯誤。因為,他們的核心能力是不一樣的。

CTO、技術總監(jiān)、架構師的核心能力是技術判斷力。簡單來講,就是判斷一個項目、一個系統(tǒng)架構、某個技術方向,是否符合企業(yè)當前現(xiàn)狀,是否對企業(yè)的未來產生價值。

程序員的核心能力是寫代碼的能力。就是做具體的代碼實現(xiàn)。

所以 CTO/技術總監(jiān)/架構師,跟程序員的核心能力,是完全不一樣的能力,是沒法作直接比較的。

通常我們說,CTO、技術總監(jiān)、架構師們很牛逼,指的是他們的技術判斷力牛逼,而不是他們寫代碼的能力牛逼。相反,他們寫代碼的能力可能還比不上一個資深程序員。

但是,他們所做的技術判斷,給公司帶來非常高的價值。比如,阿里云創(chuàng)始人王堅博士,在所有人反對的時候,他堅持云計算是未來,幫助阿里提前布局云計算,為阿里成長為萬億商業(yè)帝國,立下汗馬功勞。這就是技術判斷力,給企業(yè)帶來的巨大價值。

大家之所以都很容易混淆這幾個角色,以及它們的職責,其實很重要的一個原因就是,人們常常把 CTO、架構師、技術經理的頭銜,亂授予技術負責人。在國內這種現(xiàn)象尤其嚴重。

比如,一個初創(chuàng)公司的技術負責人,實際干的活就是個技術經理。老板為了顯得高大上,硬要給他安一個 CTO 的頭銜。這種情況很普遍,特別是全民創(chuàng)業(yè)的那幾年,遍地都是 CTO。

為了說清楚技術負責人的職責,我們以一個電商公司的成長為例,講解企業(yè)在初創(chuàng)期、發(fā)展期、成熟期的不同階段,都需要什么樣的技術負責人,以及他們具體都干些什么。

第一階段,高級程序員

實現(xiàn)復雜功能,解決技術難題

一個剛剛起步的創(chuàng)業(yè)公司,通常只有幾個程序員,甚至連產品經理、項目經理都沒有,老板自己就是產品經理,把想法跟開發(fā)人員一說,就快速地做出原型。

如果這個階段對開發(fā)的能力不滿,那么大概需要的只是一個高級開發(fā)人員,他能搞定一般的技術難題,實現(xiàn)復雜功能,思路清晰、干活利索。千萬不要去大廠挖個技術總監(jiān),你家廟太小,供不起這么大的神,他真來了也發(fā)揮不了應有的作用。

老讀者知道,老K有過一段創(chuàng)業(yè)經歷,當時追隨我的老領導出來創(chuàng)業(yè),我就是名義上的 CTO,帶了7、8人的團隊,我還同時帶了兩個項目,每個項目里我都貢獻了30%以上的代碼量。其實,當時的我,就是個高級程序員而已。

小結一下,高級程序員的主要職責是:

1,實現(xiàn)復雜功能,編寫核心代碼;

2,處理線上bug,解決技術難題。

第二階段,技術經理

交付效率提高、質量提升

當公司的業(yè)務發(fā)展起來后,就需要一支相對完善的技術團隊,有了專職產品經理、測試人員等,團隊規(guī)模在15人左右,專注于一條產品線。

復雜功能、技術難題,高級開發(fā)人員可以搞定,但是如果要解決開發(fā)團隊效率、技術人員能力提升、代碼質量和編碼規(guī)范等,就需要技術經理了。技術經理通常寫少量的代碼,更多做技術管理、項目團隊等工作。

這就是許多創(chuàng)業(yè)公司A輪融資前的情況。由技術經理總體負責技術團隊,產品經理對接業(yè)務需求,做產品規(guī)劃、競品分析,而不是抄襲哪個App。

小結一下,技術經理的職責是:

1、開發(fā)任務分派。開發(fā)工作量評估、分派,最大化資源利用率;

2、代碼質量提升。Code Review、編碼規(guī)范、線上bug分析;

3、項目管理。確保項目的按時交付,建立管理機制;

4、團隊管理。團隊搭建、人員招聘、人員培養(yǎng)。

第三階段,技術總監(jiān)

技術規(guī)劃、多產品線、項目群管理

當技術團隊發(fā)展到30人左右,有了多條核心產品線、有了多個技術經理時,就需要一個技術總監(jiān)了。

技術總監(jiān),作為領域專家,站在更高的層面思考技術如何建立壁壘,構建技術競爭力。逐步開始建立公共技術平臺,協(xié)調多條產品線在統(tǒng)一的技術平臺上快速迭代,讓產品線跑得快、跑得穩(wěn)。

技術總監(jiān),在領域內有多年沉淀,來自知名互聯(lián)網企業(yè),能夠把技術團隊帶上一個新的臺階。技術總監(jiān),更多是做技術判斷了,也有些技術型的技術總監(jiān)仍然會寫些核心代碼、做架構設計。

技術總監(jiān)的職責:

1、搭建公司技術平臺部,統(tǒng)一技術棧;

2、建立產品研發(fā)體系,讓技術團隊可持續(xù)性地快速交付;

3、管理和協(xié)調多條產品線,打造明星產品;

4、建立技術壁壘,形成技術競爭力;

第四階段,架構師

架構設計、架構實現(xiàn)、架構評審

公司如果“跑到”了B輪,技術團隊應該要接近百人了,此時的技術團隊跟初創(chuàng)時期相比,已經很不錯了。

有技術總監(jiān)協(xié)調著各產品線,有開發(fā)經理帶領技術團隊快速迭代產品。代碼規(guī)范、最佳實踐的總結和推廣也在逐步開展。

此時,需要把架構規(guī)劃和架構評審的職能從技術總監(jiān)和開發(fā)經理身上剝離,即分離專業(yè)崗和管理崗,專業(yè)人做專業(yè)事。

這時候就需要設立架構師崗位,專注于技術架構分析、架構設計、架構實現(xiàn)、推動重構、推行架構原則等工作,讓技術總監(jiān)和技術經理側重在項目管理、團隊管理。

架構師的職責是:

1、業(yè)務架構設計和實現(xiàn)。根據業(yè)務規(guī)劃和應用場景,設計切合當前業(yè)務要求,并且具備一定前瞻性的應用架構、類、接口、業(yè)務抽象及業(yè)務建模等。

2、架構設計和實現(xiàn)。識別非功能性需求,如性能、可擴展性、安全性、高可用及易部署等。

3、重構計劃及執(zhí)行。關注全鏈路監(jiān)控數據、線上bug、系統(tǒng)預警等信息,識別架構缺陷,提出重構建議并推動執(zhí)行。

第五階段,CTO

技術產品戰(zhàn)略規(guī)劃,提升技術競爭力

當技術團隊有了幾名總監(jiān)、架構師,人數達到幾百人,是時候引入真正意義上的 CTO 了,除非 CTO 是聯(lián)合創(chuàng)始人,否則這個 CTO 會有“虎落平陽”的感覺,公司也會覺得這個人“滿嘴跑火車,卻落不了地”。

國內的中大型互聯(lián)網公司,一般有產品 VP 和技術 VP,有的技術 VP 就是 CTO。如果 CTO 統(tǒng)管技術和產品,那么產品 VP 就給 CTO 匯報,否則他們是平級的。

在國外,CTO 主要研究 3~5年的技術發(fā)展趨勢,為公司做中長期的技術規(guī)劃,是具有行業(yè)影響力的技術大咖,公司技術領域的精神領袖。CTO 較少關注當下的具體事務,這類工作主要由工程副總裁們處理。

以國內互聯(lián)網公司CTO為例,總結一下CTO的主要職責:

1、技術賦能商業(yè)。敏銳的商業(yè)洞察、深入的產業(yè)研究、參與公司戰(zhàn)略規(guī)劃,技術引領業(yè)務增長,通過技術和產品實現(xiàn)戰(zhàn)略落地。

2、技術趨勢研究。思考未來3~5年的技術發(fā)展趨勢,以及新技術發(fā)展給企業(yè)帶來的機遇和風險,為企業(yè)提前布局。

3、技術治理體系。持續(xù)的過程改進、高效的研發(fā)流程、穩(wěn)定的交付質量、高可用的系統(tǒng)。

4、組織與文化。建設學習型組織、自我完善型組織,建立符合企業(yè)特色的文化氛圍。

結語

最后,不想當 CTO 的程序員,不是好騎手。從程序員到 CTO 的成長過程,需要不斷提升技術能力、產品能力、項目能力、管理能力、商業(yè)視野、個人影響力、行業(yè)人脈等等。除了自身的奮斗之外,機會和運氣同樣重要,而且是可遇不可求的。但是,夢想還是要有的,萬一見鬼了呢。


推薦適合快速成長的好課程:


0 人點贊