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

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

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


關註「 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 請求的處理流程與機制

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

-Advertisement-
Play Games
更多相關文章
  • 沙箱 沙箱: 環境, 黑盒, 在一個虛擬的環境中模擬真實世界, 做實驗, 實驗結果和真實世界的結果是一樣, 但是不會影響真實世界 全局變數 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、繼承在給程式設計帶來便利的同時,也帶來了弊端。比如使用繼承會給程式帶來侵 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...