主頁 > 前端設計 > 如何突破java程式員瓶頸?十年Java架構師分享自己的辛酸成長歷程

如何突破java程式員瓶頸?十年Java架構師分享自己的辛酸成長歷程

2020-10-11 08:20:46 前端設計

不知不覺,金九銀十已經過去一半了,小編最近也是收到了蠻多讀者的私信與簡歷,
發現了一個比較值得我注意的點就是很多讀者的簡歷千篇一律:

作業五年經驗的簡歷竟然和作業一年的簡歷并無二致!!!

所以小編今天根據阿里的一位“十年Java架構師作業經驗 ”和大家分享下程式員的成長歷程,

并在文章末尾為大家分享架構師的完整學習資料,

一、工程師

階段描述

成為一個合格的工程師需要 1~3 年時間,其典型特征是“在別人的指導下完成開發”,這里的“別人”主要是“高級工程師”或者“技術專家”,通常情況下,高級工程師或者技術專家負責需求分析和討論、方案設計,工程師負責編碼實作,高級工程師或者技術專家會指導工程師進行編碼實作,

成長指導

工程師階段是最原始的“基礎技能積累階段”,主要積累基礎知識,包括編程語言、編程工具、各類系統的基本使用,以 Java 后端工程師為例,工程師階段需要積累的經驗和技能有:

Java 的語法、基本資料結構的使用,

Eclipse、IDEA、Maven、Linux 命令列等各種工具,

資料庫 CRUD 操作、快取的基本使用等,

業務系統的基本流程,

工程師階段最好的學習方法就是 找經典的書籍系統地學習,而不要遇到一個問題到網上搜搜然后就解決了事,以 Java 為例,《Java 編程思想》《Java 核心技術》《TCP/IP 協議》這類大部頭,一定要完整地看一遍,即使里面很多內容當前作業暫時用不上,

二、高級工程師

階段描述

成長為高級工程師需要 2~5 年時間,其典型特征是“獨立完成開發”,包括需求分析、方案設計、編碼實作,其中需求分析和方案設計已經包含了“判斷”和“選擇”,只是范圍相對來說小一些,更多是在已有架構下進行設計,以 Java 后端工程師為例,高級工程師需要完成的作業包括:

MySQL 資料庫表如何設計,是設計成兩個表還是三個表?

是否要用快取,快取的 Key 和 Value 如何設計,快取的更新策略是什么?

產品提出的需求是否合理?是否有更好的方式來滿足?

成長指導

從普通工程師成長為高級工程師,主要需要“積累方案設計經驗”,簡單來說就是業務當前用到的相關技術的設計經驗,以 Java 后端高級工程師為例,包括:表設計經驗、快取設計經驗、業務流程設計經驗、介面設計經驗等,當接到一個業務需求的時候,高級工程師能夠組合這些設計經驗,最終完成業務需求,

高級工程師階段相比工程師階段,有兩個典型的差異:

深度:如果說工程師是要求知道 How,那高級工程師就要求知道 Why 了,例如 Java 的各種資料結構的實作原理,因為只有深入掌握了這些實作原理,才能對其優缺點和使用場景有深刻理解,這樣在做具體方案設計的時候才能選擇合適的資料結構,

理論:理論就是前人總結出來的成熟的設計經驗,例如資料庫表設計的 3 個范式、面向物件的設計模式、SOLID 設計原則、快取設計理論(快取穿透、快取雪崩、快取熱點)等,

針對技術深度,我的建議還是系統地學習,包括看書和研究原始碼,例如,研究 Java 虛擬機可以看《深入理解 Java 虛擬機》、研究 MySQL 可以看《MySQL 技術內幕:InnoDB 存盤引擎》、研究 Memcache 可以去看其原始碼,

針對設計理論,由于涉及的點很多,沒有一本書能夠涵蓋這么多的設計點,因此更多的是依靠自己去網上搜索資料學習,那我們怎么知道哪些地方會有設計理論呢?簡單來說,就是假設每個設計環節都有設計理論,然后帶著這種假設去搜索驗證看看是否真的有很熟的設計理念,

三、技術專家

階段描述

成長為技術專家需要 4~8 年時間,其典型的特征是“某個領域的專家”,通俗地講,只要是這個領域的問題,技術專家都可以解決,例如:Java 開發專家、PHP 開發專家、Android 開發專家、iOS 開發專家、前端開發專家等,通常情況下,“領域”的范圍不能太小,例如我們可以說“Java 開發專家”,但不會說“Java 多執行緒專家”或“Java JDBC 專家”,

技術專家與高級工程師的一個典型區別就是,高級工程師主要是在已有的架構框架下完成設計,而技術專家會根據需要修改、擴展、優化架構,例如,同樣是 Java 開發,高級工程師關注的是如何優化 MySQL 的查詢性能,而技術專家可能就會考慮引入 Elasticsearch 來完成搜索,

成長指導

從高級工程師成長為技術專家,主要需要“拓展技術寬度”,因為一個“領域”必然會涉及眾多的技術面,以 Java 后端開發為例,要成為一個 Java 開發專家,需要掌握 Java 多執行緒、JDBC、Java 虛擬機、面向物件、設計模式、Netty、Elasticsearch、Memcache、Redis、MySQL 等眾多技術,常見的拓展技術寬度的方法有:

學習業界成熟的開源方案,例如,Java 開發可以去學習 Redis、Memcache、Netty 等,Android 開發可以去研究 Retrofit、Fresco、OkHttp 等,

研究業界的經驗分享,例如 BAT、FANG 等大公司的經驗,可以通過參加技術大會等方式去近距離了解,

需要注意的是,拓展技術寬度并不意味著僅僅只是知道一個技術名詞,而是要深入去理解每個技術的原理、優缺點、應用場景,否則就會成為傳說中的“PPT 技術專家”,例如,以 Java 開發為例,知道 Netty 是個高性能網路庫是遠遠不夠的,還需要學習 Netty 的原理,以及具體如何使用 Netty 來開發高性能系統,

四、初級架構師

階段描述

成長為初級架構師需要 5~10 年時間,其典型特征就是能夠“獨立完成一個系統的架構設計”,可以是從 0 到 1 設計一個新系統,也可以是將架構從 1.0 重構到 2.0,初級架構師負責的系統復雜度相對來說不高,例如后臺管理系統、某個業務下的子系統、100 萬 PV 量級的網站等,

初級架構師和技術專家的典型區別是:架構師是基于完善的架構設計方法論的指導來進行架構設計,而技術專家更多的是基于經驗進行架構設計,簡單來說,即使是同樣一個方案,初級架構師能夠清晰地闡述架構設計的理由和原因,而技術專家可能就是因為自己曾經這樣做過,或者看到別人這樣做過而選擇設計方案,

但在實踐作業中,技術專家和初級架構師的區別并不很明顯,事實上很多技術專家其實就承擔了初級架構師的角色,因為在系統復雜度相對不高的情況下,架構設計的難度不高,用不同的備選方案最終都能夠較好地完成系統設計,例如,設計一個日 PV 100 萬的網站,MySQL + Memcache + Spring Boot 可以很好地完成,MongoDB + Redis + Nginx + php-fpm 也可以很好地完成,備選方案設計和選擇并不太難,更多的是看團隊熟悉哪個技術,

成長指導

從技術專家成長為初級架構師,最主要的是形成自己的“架構設計方法論”,我的架構設計專欄其實就是講述完整的架構設計方法論,包括架構設計目的、架構設計原則、架構設計步驟、架構設計模式等,類似的架構設計方法論還有《恰如其分的軟體架構:風險驅動的設計方法》和《領域驅動設計》等,

要形成自己的架構設計方法論,主要的手段有:

系統學習架構設計方法論,包括訂閱專欄或者閱讀書籍等,

深入研究成熟開源系統的架構設計,這個手段在技術專家階段也會用到,但關注點不一樣,同樣是研究開源系統,技術專家階段聚焦于如何更好地應用開源專案;初級架構師階段聚焦于學習其架構設計原理和思想,例如 Kafka 的檔案中就有關于訊息佇列架構設計的分析和取舍,

結合架構設計方法論,分析和總結自己團隊甚至公司的各種系統的架構設計優缺點,嘗試思考架構重構方案,如果在這個基礎上真的能夠推動架構重構,那就更好了,既能夠實踐自己的架構設計方法論,同時積累經驗,又能夠展現自己的技術實力,拿到結果,

五、中級架構師

階段描述

成長為中級架構師需要 8 年以上時間,其典型特征是“能夠完成復雜系統的架構設計”,包含高性能、高可用、可擴展、海量存盤等復雜系統,例如設計一個和 Kafka 性能匹敵的訊息佇列系統、將業務改造為異地多活、設計一個總共 100 人參與開發的業務系統等,

中級架構師與初級架構師的典型區別在于系統復雜度的不同,中級架構師面對的系統復雜度要高于初級架構師,以開源專案為例,初級架構師可能引入某個開源專案就可以完成架構設計,而中級架構師可能發現其實沒有哪個開源專案是合適的,而需要自己開發一個全新的專案,事實上很多開源專案就是這樣誕生出來的,

成長指導

從初級架構師成長為中級架構師,最關鍵的是“技術深度和技術理論的積累”,例如:

技術理論:CAP、BASE 是異地多活的設計理論基礎、Paxos 是分布式一致性的基礎演算法、2PC、3PC 是分布式事務的基礎演算法等,

技術深度:Kafka 用磁盤存盤還能做到高效是因為磁盤順序寫;Disruptor 高性能是結合 CPU 預讀取機制、快取行、無鎖設計等基礎技術;Storm 的高效異或確認機制;Flink 的分布式快照演算法等,

很多同學對這點可能有疑問,這些技術理論和技術深度的事情不應該是高級工程師階段或者技術專家階段就應該積累的么?為何到了中級架構師階段反而是成長的關鍵了呢?主要原因在于高級工程師或者技術專家階段即使去學習這些技術,實際上也比較難理解透徹,更加難以有機會去應用,更多的時候只是了解有這個技術點而已;而到了中級架構師階段,面對高復雜度的系統,很多時候就是幾個關鍵技術細節決定整個架構設計的成敗,或者某個設計方案理論上就是不可行的,如果不深刻理解理論和相關的關鍵技術點,很難設計優秀的架構,

以我做過的異地多活設計方案為例,之前很早我就知道 CAP 理論了,但也僅僅只是知道幾個概念而已,真正做異地多活的時候,開始的時候還是走了不少彎路,試圖做一個完美的異地多活系統,最終發現這其實是不可能的,某天突然頓悟:其實 CAP 理論已經明確指出來了這點,但最初學習 CAP 理論的時候,很難有這樣深刻的理解,

六、高級架構師

階段描述

成長為高級架構師需要 10 年以上時間,其典型特征是“創造新的架構模式”,例如:

谷歌大資料論文,創造了分布式存盤架構、分布式計算 MapReduce 架構、列式存盤架構,開創了大資料時代,

在有 MapReduce 分布式計算架構的背景下,Storm 又創造了流式計算架構,

在虛擬機很成熟的背景下,Docker 創造了容器化的技術潮流,

高級架構師與中級架構師相比,典型區別在于“創造性”,高級架構師能夠創造新的架構模式,開創新的技術潮流,

對于2-5年的Java程式員我們應當如何來學習提升呢?下面是筆者收集整理的學習線路圖,需要的可自行下載,

(一)深入JDK原始碼,分析JVM底層原理

(二)深入JavaSE原始碼實作

(三)攻破java難點,徹底掌握并發編程

(四)互聯網面試必備,深入開發框架原始碼

(五)全面掌握網路通信

(六)深入作業系統內核原理

(七)年薪百萬,必須掌握的分布式技術

(八)微服務技術

(九)資料庫原理與調優

(十)系統運維與監控技術

(十一)架構思維

(十二)并發實戰專案

方向比學習更重要!了解了架構師的成長路線,就更容易擺脫瓶頸現狀,小編這里為大家準備好了,對應的架構師資料
領取方式:戳這里,戳這里,暗號:CSDN

史上最全最詳細的Java架構師成長路徑圖,程式員必備

史上最全最詳細的Java架構師成長路徑圖,程式員必備

史上最全最詳細的Java架構師成長路徑圖,程式員必備

以上技術方向我們有自己的高清思維方向導圖以及阿里架構師講解的架構視頻分享(包括高可用,高并發,spring原始碼,mybatis原始碼,JVM,大資料,Netty等多個技術知識的架構視頻資料和各種電子書籍閱讀)視頻資料,以及一些一線互聯網公司的面試題決議含答案,領取方式:戳這里,戳這里,暗號:CSDN

希望文章對大家有幫助,也祝愿大家早日升職加薪迎娶白富美走上人生巔峰,喜歡文章請點個關注,三連~~

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/167532.html

標籤:其他

上一篇:大廠面試力推!精挑細選打造的“Java面試題”沒有那么多糟粕,留下的都是精華!行與不行,客官看完說話!

下一篇:BAT大廠Java面試,如何抓住面試重點知識?收割大廠offer

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more