程式員,如何從開發轉型做架構師?

来源:https://www.cnblogs.com/itlaobingge/archive/2020/01/10/12176418.html

人生就像射箭,如果連箭靶都找不到,那每天的拉弓又有何意義呢?本文主要價值是分享老兵哥我個人真實的從業經歷經驗,希望讓你對架構和架構師有充分的瞭解,從而做好開發工作,並結合個人興趣愛好提前規劃未來。 ...


關註「 IT老兵哥 」,賦能程式人生。本系列前序文章索引:

  1. 程式員為什麼必須要懂架構?
  2. 架構到底是什麼,你知道嗎?
  3. 架構都有哪些,我該怎麼選?
  4. 架構師都乾什麼,你知道嗎?
  5. 練就哪些技能才勝任架構師?
  6. 怎樣才能搞定上下游的客戶?

人生就像射箭,如果連箭靶都找不到,那每天的拉弓又有何意義呢?本文主要價值是分享老兵哥我個人真實的從業經歷經驗,希望讓你對架構和架構師有充分的瞭解,從而做好開發工作,並結合個人興趣愛好提前規劃未來。

1. 哪些特質適合往架構方向發展?

按照古典老師的生涯三葉草模型,構建某項新技能要從興趣出發,接著培養能力,再將能力變現創造價值,最後激發更大的興趣,形成良性迴圈。因此,程式員在選擇自己升級打怪的路徑時必須要遵從內心,人生沒有好走的路,每個方向都需要付出努力才能在競爭中不被淘汰,如果能夠選擇自己喜歡並適合的發展方向,那你就會走的更加快樂從容一些。結合個人成長,以及擔任面試官、晉升評委等經歷,老兵哥總結了幾個適合往架構方向發展的特質:

  • 對技術有足夠的熱情和好奇心。這些年技術的更新換代非常快,如果你對技術缺乏熱情或好奇心,那你就很容易被時代所拋棄,滯留在曾經最擅長最熟悉的技術棧上。只有保持對新生事物的好奇心,願意擁抱變化,才能夠不斷刷新自己的技術棧,從而積累豐富的經驗,拓展自己的認知。
  • 善於跳出紛繁抽象總結方法論。在這個充滿變幻的環境中,我們很容易陷入細節不能自拔,被各種業務問題套住不能脫身,意識不到跳出這些變化來總結共性的解決方案,從更高的維度來解決問題。如果你平時喜歡流程化、層次化、系統化地思考問題,那你就具備了做架構的基本條件。
  • 樂於與人溝通交流,興趣愛好寬泛。架構師需要跟各種干係人角色溝通交流,如果你本身不太喜歡跟人打交道,那麼架構相關的工作對你來說就比較有挑戰。相對於技術專家的精深,架構更偏廣博,興趣愛好寬泛就有助於你拓寬自己的技術面和人脈圈,從而為做好架構積累內外資源。

如果你對某個技術領域特別喜歡,性格相對內向,興趣愛好單一,那就可以往專精方向發展,成為這個領域的技術專家。如果你性格外向,興趣愛好寬泛,那就可以往廣博方向發展,成為跨不同領域的架構專家。不管往哪個方向發展,最根本的就是充分發揮自身優勢,不斷提高自己的不可替代性,站上更高更大的舞臺,做更大更有價值的事情。

2. 如何從開發成功轉型架構師?

2.1 個人經歷介紹

老兵哥我第一份工作的崗位是高級開發工程師,兩年左右升職為技術經理,其中百分之七十的時間精力依舊在開發工作上,其餘百分之三十的時間精力用於十多個人左右團隊的日常管理。這次跳槽換工作的主要原因,公司主營業務通信是基礎設施,它本身跟互聯網業務的關係比較遠,那時候移動互聯網開始蓬勃發展,而通信行業主要是跟著國際電信論壇的標準在走,雖然當時我們公司也在參與國際標準的制定,但就像待在大海深處無法感受到海面的波瀾壯闊,世界那麼大,我想去看看,年輕時的好奇心引領我奔向了移動互聯網。

第二份工作的崗位是研發項目經理,兼職架構。當時移動互聯網正處於爆發階段,我在這段工作期間經歷了從零開始孵化項目,技術架構也不短迭代升級。剛開始我並沒有意識到要往架構師方向發展,都是在業務野蠻生長過程中遇到各種問題後被逼著趕鴨子上架,邊查資料邊驗證,壓力很大,但成長也比較快。在這個過程中,我習慣結構化思維,能夠從更加系統化的角度分析定位問題,當時的領導覺得我有往架構師方向發展的潛力,專門讓我參加了一個外部的架構師訓練營。這個訓練營對我的幫助還是蠻大的,它讓我對架構有了更加系統化的認知,幫我構建了架構相關的知識體系。從那以後,我就會有意識地按照架構思維來看待各種技術工作。

後來跳槽換第三份工作的主要原因是,BAT 這類企業發展特別快,它們的業務都是服務個人用戶,相較於服務企業團體客戶,我們技術人的價值更容易得到體現和尊重,企業文化也是偏工程師文化。不同的生態需要不同的生存技能,選擇環境也就是在強化自己想擁有的技能。第三份工作我的崗位是應用架構專家,主要奔著做公有雲這個大方向去的,既可以服務個人或中小企業客戶,又可以緊跟雲計算這個大趨勢。這段工作讓我有機會刷新自己的技術棧,積累了大量雲應用架構、微服務架構的實踐經驗,在培訓推廣、售前支持等工作中提升了軟技能。

架構師這個崗位需要廣博的知識面,而這幾段工作經歷極大地豐富了我的技術視野和知識體系,實踐過 C/S、B/S、分散式 Dubbo、微服務 Spring Cloud 等應用架構,開發過 Windows 桌面應用、Anroid 移動應用、Linux 伺服器程式等,熟練或熟悉使用 C/C++、JAVA、JavaScript、Python 等開發語言,使用過各種類型的中間件產品。在三十歲前後正在構建架構師所需的技能樹,而隨後順利轉型至架構師崗位,比較平滑地渡過了程式員 35 歲這道坎,現在回過頭來看,這恰巧符合了職業轉型升級三步走的策略。

2.2 三步走轉型策略
我們每個人都會遇到轉型升級這個命題,要麼是被動的,要麼是主動的。什麼是被動呢?就是職業發展遭遇瓶頸或天花板,薪酬待遇上漲乏力,相對於年輕人在市場上的競爭力降低,甚至遭遇末尾淘汰或裁員等等,這是任何人都不願意看到的,最好還是提前規劃主動轉型。當然,任何人都不能脫離現實生存的約束,在完成轉型升級前,我們還需要依靠眼下最擅長的技能謀生。因此,我們不要幻想自己在某天就突然可以勝任架構師的工作了,最靠譜的還是三步走策略:

  • 第一步,在開發崗上積累豐富的開發和設計經驗,熟悉各種中間件產品。
  • 第二步,在開發崗上學習架構相關的理論和方法,尋找機會做架構設計,提升架構師所需的軟技能。
  • 第三步,晉升或跳槽到真正的架構崗,正式以架構師角色開展工作,培育後續轉型升級的新技能樹。

上述三步當中,第二步比較難,在做好本職工作的同時,主動跳出舒適區,不斷擴大自己的技術視野。因為很多人會被公司的業務和技術環境牽著走,例如公司當前的業務規模決定了技術上不需要分散式技術,很少有人會思考業務規模大了之後如何利用分散式技術來化解問題。如果你準備往架構師方向發展,除了尋找更大規模的業務外,那你要養成跳出當前層級和環境來思考的習慣,例如你只用了關係型資料庫,有沒有想過當數據到達 TB 數量級時如何快速檢索與保存呢?技術能力的突破依賴業務場景的需求和自身刻意的規劃學習,二者缺一不可。但前者是機會,往往不是自己能完全把控的,如果在工作中沒有實踐場景,最好的辦法就是系統的學習與梳理,待機會來臨時才能一展身手。

考慮到我們每個人的工作學習情況不同,遇到的問題也不同,本文內容無法覆蓋所有問題,歡迎大家留言提問,或者關註公眾號「IT老兵哥」找我交流探討,我會儘力儘快解答大家提出的問題。如果你對這個主題感興趣,千萬要記得先關註哦!堅持原創不易,如果你覺得有價值,麻煩動動手指點下文 「 推薦 」按鈕,讓更多小伙伴可以看到,老兵哥會更有動力堅持分享的。另外,我後續還會分享職業規劃、應聘面試、技能提升、影響力打造等經驗,歡迎 關註 本專欄或微信公眾號 「 IT老兵哥 

 

  • 軟技能-熱門文章:(首發公眾號)
  1. 如何在打造影響力的路上「碼」不停?(
  2. 2020 來了,你的 2019 曬好封存了嗎?(
  3. “花式”裁員套路深,你知道嗎?
  4. 遭遇裁員,如何渡過心理危機?
  5. 程式員“求包養”攻略揭秘

 

  • 硬技能-熱門文章:
  1. 如何設計出優美的Web API?
  2. 程式員必須掌握的性能調優 X Y Z (
  3. 如何把單體式應用拆解成微服務?【上】
  4. 如何把單體式應用拆解成微服務?【下】
  5. 圖解 Spring:HTTP 請求的處理流程與機制

您的分享是我們最大的動力!

更多相關文章
  • 沙箱 沙箱: 環境, 黑盒, 在一個虛擬的環境中模擬真實世界, 做實驗, 實驗結果和真實世界的結果是一樣, 但是不會影響真實世界 全局變數 var num=10; console.log(num+10); //沙箱 小環境 (function () { var num = 10; console.l ...
  • 導航守衛 一、全局導航守衛 1. 全局導航守衛,把方法給 router,只要路由發生改變跳轉都會觸發這個函數 2. 每個路由 都有一個 meta 3. 全局導航守衛分兩種: 1. 全局前置導航守衛:路由還沒有跳轉之前 2. 全局後置導航守衛:路由跳轉之後 3. to 和 from 都是 router ...
  • 路由的緩存 路由緩存是 Vue組件優化的一個重要方法 為什麼實現路由緩存? 為了 組件間 相互切換不會重覆載入數據,影響用戶體驗,我們通常需要將組件的數組實現緩存,當我們點過來,在點的時候會再次發送 ajax,想讓它發送之後把數據存起來。 我們需要,當我點擊的時候直接出來 <keep-alive> ...
  • ©Copyright 蕃薯耀 2020-01-10 https://www.cnblogs.com/fanshuyao/ 一、官網地址: https://github.com/blueimp/jQuery-File-Upload 二、使用文檔(參數說明) https://github.com/blu ...
  • 各位朋友 因 最近工作繁忙,小編停更了一段時間,快過年了,小編祝願 大家 事業有成 學業有成 快樂健康 2020開心過好每一天。從今天開始 我會抽時間把 Vue 的知識點補充完整,以及後期會帶給大家更完善的知識體系!!! 路由的按需載入(懶載入) 我們都知道 vue的路由是我們必學的,也是不可分離的 ...
  • 基本介紹 1、一個對象應該對其他對象保持最少的瞭解 2、類與類關係越密切,耦合度越大 3、迪米特法則又叫 最少知道原則 ,即一個類對自己依賴的類知道的越少越好。也就是說,對於被依賴的類不管多麼複雜,都儘量將邏輯封裝在類的內部。對外除了提供public方法,不對外泄露任何信息 4、迪米特法則還有個更簡 ...
  • 基本介紹 1、開閉(ocp)原則時編程中最基礎、最重要的設計原則 2、一個軟體實體如類、木塊和函數應該對擴展開放,對修改關閉。用抽象構建框架,用實現擴展細節。 即對提供方開放,對使用方關閉 。 3、當軟體需要變化時,儘量 通過擴展軟體實體的行為類實現變化,而不是通過修改已有代碼來實現變化 4、編程中 ...
  • oo中的繼承性的思考和說明 1、繼承包含這樣一層含義:父類中凡是已經實現好的方法,實際上是在設定規範和契約,雖然它不強制要求所有的子類必須遵循這些七月,但是如果子類對這些已經實現的方法任意修改,就會對整個繼承體系造成破壞。 2、繼承在給程式設計帶來便利的同時,也帶來了弊端。比如使用繼承會給程式帶來侵 ...
一周排行
  • 這是一個個人敘述自己建設博客的帖子,既然是第一篇那肯定是不牽扯代碼了,主要講一下大體的東西,微軟最新的web框架應該就數asp.net core 3.1了這是一個長期支持版,而且是跨平臺又開源版本,所以大家可以去GitHub上找源碼,也可以研究源碼是怎麼寫的。 大過年的偏偏出現這個疫情,所以只能窩屋 ...
  • 上一篇帖子講了用了哪些技術,這個帖子就先介紹介紹api項目吧,項目就是一個普通的webapi項目,賬戶系統用的identity ,什麼是identity呢? 其實就是官方封裝好的一系列的可以用來操作資料庫的類,對用戶信息進行增刪改查。主要牽扯的類有如下幾個: UserManager SignInMa ...
  • 1、添加php的yum軟體倉庫 sudo rpm -Uvh https://mirror.webtatic.com/yum/el6/latest.rpm 2、安裝php相關軟體,執行過程中全部選擇yes即可 sudo yum install php71w.x86_64 php71w-cli.x86_ ...
  • 預設情況下,CentOS6 64 bit 已經早已不支持php5.2.x ,但是某些php程式還需要zend optimizer支持,怎麼辦呢?目前大部分的yum repos 都已經不支持直接安裝php5.2了,怎麼在CentOS6.x/6.5/6.4/6.3/6.2/7.x 64位安裝php5.2 ...
  • Dart Bool類型和其他語言類似,比較簡單 其特點有: 1.使用 bool 表示布爾類型 2.布爾值只有 true 和 false 3.布爾類型bool預設值是null bool isTrue = true; bool isFalse = false; bool defaultBool ; pr ...
  • 今天在資料庫中生成數據表,生成遷移文件時報了一堆錯。 最重要的就是TypeError: __init__() missing 1 required positional argument: 'on_delete', 他說我缺少一個必要的參數。 代碼如下: 關聯外鍵 sgrade = models.F ...
  • —— 終端中的編輯器 01. 簡介 在工作中,要對 伺服器 上的文件進行 簡單 的修改,可以使用 遠程登錄到伺服器上,並且使用 進行快速的編輯即可 常見需要修改的文件包括: 源程式 配置文件 ,例如 的配置文件 在沒有圖形界面的環境下,要編輯文件, 是最佳選擇! 每一個要使用 Linux 的程式員, ...
  • 認識 Python 人生苦短,我用 Python —— Life is short, you need Python 01. Python 的起源 Python 的創始人為吉多·範羅蘇姆(Guido van Rossum) 1. 1989 年的聖誕節期間,吉多·範羅蘇姆為了在阿姆斯特丹打發時間,決心 ...
  • 01. 第一個 程式 1.1 Python 源程式的基本概念 1. Python 源程式就是 一個特殊格式的文本文件 ,可以 使用任意文本編輯軟體 做 的開發 2. Python 程式的 文件擴展名 通常都是 1.2 演練步驟 在桌面下,新建 目錄 在 目錄下新建 文件 使用 gedit 編輯 並且 ...
  • PyCharm 的官方網站地址是:https://www.jetbrains.com/pycharm/ 01. 恢復 PyCharm 的初始設置 的 配置信息 是保存在 用戶家目錄下 的 目錄下的, 表示當前使用的 的版本號 如果要恢復 的初始設置,可以按照以下步驟進行: 1. 關閉正在運行的 2. ...
x