這篇文章仍是架構師大劉的故事。程序員
故事以前先說個題外話,最近到了金三銀四跳槽季,有很多讀者問我一些簡歷、面試的問題,這些問題大部分在以前的一篇硬核文章裏都寫過,傳送門在這裏:面試
很是全面的一篇程序員找工做的乾貨文章,基本涵蓋了求職的整個流程,最可貴的是除了經驗,還有不少須要的坑。還沒看過的讀者,推薦看一下,確定有幫助。網絡
題外話結束,故事開始。架構
俗子胸襟誰識我?英雄末路當磨折。莽紅塵何處覓知音?青衫溼!運維
做這首詞的本是近代女英雄秋瑾。說的倒是蔑視世俗、不畏挫折磨難的壯志雄心。此時,大劉卻亦有慼慼然焉。工具
大劉是個架構師,隨着工做的日益繁忙,已經逐漸離開了在一線寫代碼的工做。可是在離開一線的時候,也難免聽到了一些不和諧的聲音。學習
- 什麼架構師不寫底層代碼,不知道還有何用……
- 什麼架構師整天不寫代碼,之後確定廢了……
這些靡靡雜音不絕於耳,大劉不免就有了上面的情緒。測試
代碼寫很差,作不了架構師;作了架構師以後,發現有更多事情比寫代碼更重要。編碼
架構師不管從何角度來說,本質就是一位技術專家。那些架構師們由於公司的發展和職責的擴充,有的離開了一線,有的還沒有離開一線。可是,不管在不在一線,
都不影響一位技術專家的核心價值。
有某些理論說,技術專家吃技術飯的,技術是個手藝活,幾天不練就手生。可是這套理論和實際不同的是,這套「手藝活理論」,並無考慮現實裏的公司對架構師本人的核心價值定位。
之因此這樣說,是由於「手藝活理論」,只定義了技術問題就是手藝活能解決的問題,認爲技術問題都是靠寫代碼搞定的。這就跟產品經理告訴你「這個需求很簡單」同樣好笑。
架構師不寫代碼不會成爲公司吃乾飯的——要說明這個,首先得先說明下架構師的核心價值在哪裏。
有些人糊里糊塗過日子,分不出來啥叫核心價值啥叫附屬價值。剛入行,拿着還算能夠的薪資,覺得這就是他們一生的狀態。素不知這其實就是個溫柔鄉,慢慢把人套牢,而後到了中年,一切轟然崩塌,那時候,後悔也晚了。
價值這東西,放在如今打工人身上,就是你能給公司帶來多少利潤。就拿技術舉例,你給公司開發出個新產品,公司盈利了,你就體現了你的價值。
更進一步,若是你給公司弄出了新的產品,公司預估時間爲一個月,你半個月搞定了,給公司了個小 suprise,你不只體現了你應有的價值,你還買一送一,給了公司一些小小的快樂,那麼就創造出了更多的價值。
以你給公司創造出了更大價值爲前提,我們看個公式:
你實際創造的價值 = 你原本就應該給公司掙的錢 + 你優秀的能力讓公司意外賺(省)的錢
從這個公式你就能夠看出來了,價值這事兒得分紅兩個,一個是公司須要你爲公司掙錢的價值,一個是你本身能力可能比同行優秀,多搞出來的價值。
第一部分就是核心價值。那個你比同行優秀或者公司讓你搞產品,你不只搞了產品,你還把地板給掃乾淨了的價值是一些附帶的,是附屬價值。
OK,知道這事兒了,我們就得嘀咕嘀咕架構師這事兒了。大劉鬱悶在哪裏?原本架構師開不開發代碼,這事兒不是判斷架構師夠未入流的標準。
可是呢,有些人可能從小土裏刨食兒慣了,出來搞些碼農的事情,以爲不敲代碼了,就不配搞技術。手裏拿着在 2.14 還親密接觸的鍵盤,在互聯網上苟且的發表着一些陰陽怪氣的意見,這就很讓人不待見了,也很容易誤導後來的年輕人。
公司爲何須要架構師?魯迅先生說過
公司裏原本沒有架構師,系統複雜了,也就有了架構師。
架構師這崗位不是地裏長出來的,是有需求創造出來的。
看到了吧,架構師的核心價值出來了:專門用來搞定公司複雜的系統的。固然,資本家的事兒能叫剝削嗎?那叫幫你成長。爲了幫助架構師的成長,因此架構師的責任鏈條又拉長了:
從搞定一個複雜系統 -> 搞定全部的複雜系統 -> 搞定全部系統 -> 全部技術你都作主了吧
因而,架構師也是擁有本身的血淚成長史的。
好了,話題扯遠了,說回來。
公司須要搞出複雜的系統產品來運營,須要複雜的技術鏈條來運維,須要複雜的工具來加快產品開發速度……這些事兒,其實都是架構師要關心的。
在這些裏面,編碼就是其中一小部分工做,架構師忙不過來了,天然要放棄編碼,去考慮別的問題。
架構師編碼編的好,那是他高級程序員作的到位,可是這是全部技術工做中的很小的一部分。
假如大劉編碼作好了,上線無 Bug 了,可是精力沒顧上總體技術架構,也沒顧上總體的系統分析,好比
- 業務數據須要高可用仍是高一致?
- 在線運營的系統運行了好久了,是否是要搞代碼重構了?
由於大劉深刻了編碼細節,疏忽了更重要的,出現了判斷問題,那大劉的核心價值就被損害了。就算他寫代碼寫的全程絲滑,但總體系統卻沒搞的到位,對公司來講就是損失,這個架構師就不合格。
如今一些新入行的年輕人,一邊編寫着代碼,一邊被人灌輸架構師必須寫代碼,不寫代碼,他就是僞架構師,這是徹底的以偏概全。架構師其實挺難當的,上面說過,隨着你乾的活變化,極可能架構師一會兒就把公司的技術活全撈來負責了。
不少有技術追求的人,他們很想當架構師,可是又不知道該怎麼學習。根據大劉本身的經驗,你得先培養本身的三種能力:
1. 快速分析問題的能力
由於架構師有一個很重要的工做,就是負責解決公司的系統問題,不少系統的問題其實解決不難,可是定位很是困難,因此,定位問題能力就須要有意識的訓練。定位問題的能力須要能快速梳理總體流程,而後準確的找到流程中斷的地方,那個地方極可能就是問題點。固然,多見識各類系統問題也是必須的。
2. 快速學習的能力
架構師其實負責的工做很雜,幾乎任何技術工做,你都能扯上架構師。架構師就是技術工做的主負責人的各類備胎。可是,架構師也是人,他也不是萬事通。爲了能完成這些備胎工做,架構師就得可以快速學習,對一些新鮮領域能快速技術調研給出結論,對一些不熟悉的技術領域能快速的深刻學習而後找到瓶頸並解決。並且,平時也得多關注技術領域,持久化,快速化的不斷學習。
3. 快速資源調配的能力
快速資源調配的能力則是由於極可能運維、開發、測試他們面臨了一些技術問題,須要這些人一塊兒配合搞清楚。好比網絡問題,極可能運維、開發、測試都是互相埋怨甩鍋,這時候,就須要架構師們快速肯定問題,調配人員,看如何把存在的技術問題給幹掉。
看到了吧,上面哪一個都不是幹寫代碼能夠搞定的事情,因此,架構師這事兒,真的不能光看什麼寫代碼。
架構師嘛,不寫代碼不寒磣。
你好,我是四猿外。
一家上市公司的技術總監,管理的技術團隊一百餘人。
我從一名非計算機專業的畢業生,轉行到程序員,一路打拼,一路成長。
我會經過公衆號, 把本身的成長故事寫成文章, 把枯燥的技術文章寫成故事。
我建了一個讀者交流羣,裏面大部分是程序員,一塊兒聊技術、工做、八卦。歡迎加我微信,拉你入羣