最近有很多讀者問:怎樣成為一名架構(gòu)師,? 在大家眼中『架構(gòu)師』的地位高高在上,,不可逾越,其實(shí)不然,,架構(gòu)師并沒有想象中那么難,,我認(rèn)識一個(gè)小企業(yè)的架構(gòu)師,他工作了9年,,但是感覺水平也就等同于阿里 P6到 P7的水平,。 在一個(gè)公司能否成為架構(gòu)師關(guān)鍵在于你是否比你身邊的人優(yōu)秀,如果你的能力超過身邊人幾個(gè)層次,,那架構(gòu)師的職位非你莫屬了,。 廢話不多說,下面以 Java 語言為例聊聊一個(gè)剛畢業(yè)的學(xué)生如何一步一步修煉最終飛升,。 師傅領(lǐng)進(jìn)門,,修行在個(gè)人在文章中我只會(huì)指出道路,相當(dāng)于送你一本修煉武功手冊,,但修行之路還得靠個(gè)人努力,,有不明白的地方可以問谷老師,如果大家具體對哪一塊感興趣可以留言,,后續(xù)可以作為一個(gè)系列展開來講,。 階段一:煉氣煉氣其實(shí)就是對應(yīng)入門,這一階段需要掌握: 1、Java:俗稱 JavaSE,。不僅僅指 Java 語法,,還有 JDK 的使用和源碼理解,這塊知識非常龐雜也非常重要,,沉下心花幾年學(xué)好它,。推薦學(xué)習(xí)方式: (1)《Effective Java》讓你感受一下 Java 里面的彎彎繞繞,并不是簡單語法表現(xiàn)的那樣傻白甜,。 (2)OCJP 考試,,這個(gè)是 Oracle 官方的認(rèn)證考試,可以讓你全方位了解 Java 里面的細(xì)節(jié),,非常重要,。 (3)《并發(fā)編程實(shí)踐》多核 CPU 自帶 L2 cache 卻共享內(nèi)存和線程,復(fù)雜的鎖,,一行 Java 代碼卻編譯為多行機(jī)器指令而 CPU 在任意機(jī)器指令間都可切換線程,。面對這么復(fù)雜的硬件環(huán)境,Java 是如何設(shè)計(jì)保證程序正確的,。 2,、算法和數(shù)據(jù)結(jié)構(gòu) (1)Leetcode刷題。雖然只有極少的開發(fā)會(huì)用到算法,,但這是內(nèi)功的體現(xiàn),。不要以為會(huì)寫個(gè)單鏈表反轉(zhuǎn)就可以了,至少要把動(dòng)態(tài)規(guī)劃級別的算法搞懂,。 (2)《算法導(dǎo)論》,,這本讀讀就行了,希望你能讀懂,。 階段二:筑基萬丈高樓平地起,,一磚一瓦皆根基,學(xué)習(xí)和建筑一樣根基非常重要,,根基決定著你未來的高度,。飛升修仙也是一樣的,這一階段你需要掌握: 1,、設(shè)計(jì)模式:《設(shè)計(jì)模式》,,Gang Of Four。四桿老槍的設(shè)計(jì)模式,,教會(huì)你一些固定招式應(yīng)付各種經(jīng)典場景,。 2、JVM:《深入理解 Java 虛擬機(jī)》,。在早些年,,如果你說你懂 JVM 原理,,那你就是國內(nèi)Java頂尖人才了,現(xiàn)如今 JVM 知識已經(jīng)爛大街,,成為面試必備八股文,。你需要了解 JVM 如何使用內(nèi)存,如何 GC,,如何調(diào)整啟動(dòng)參數(shù),,如何查看 dump 文件。 3,、網(wǎng)絡(luò)編程:需要搞懂 HTTP,、TCP/IP 協(xié)議,了解一根網(wǎng)線如何串起整個(gè)網(wǎng)絡(luò),。 4,、分布式系統(tǒng)各種中間件 (1)Dubbo,這是國內(nèi)最知名的開源項(xiàng)目之一,,找一本阿里出的 dubbo 書讀,。無中心化分布式架構(gòu)的核心取代了 IBM 的 SOA 產(chǎn)品(中心化架構(gòu)容易造成性能瓶頸)。 (2)ZooKeeper,,推薦讀 ZooKeeper 小紅書,。ZK 是分布式系統(tǒng)數(shù)據(jù)一致性協(xié)調(diào)工具。在單機(jī)進(jìn)程中代碼執(zhí)行被認(rèn)為是完全可靠的,,要么執(zhí)行成功要么執(zhí)行失敗,,而到了分布式系統(tǒng),進(jìn)程之間網(wǎng)絡(luò)調(diào)用經(jīng)常會(huì)出現(xiàn)超時(shí),,出現(xiàn)超時(shí)就麻煩了,到底是成功了還是失敗了沒法簡單判斷,。理解 CAP 理解分布式系統(tǒng)數(shù)據(jù)的一致性是分布式系統(tǒng)不出錯(cuò)的保障,。 (3)Kafka,推薦《Kafka 權(quán)威指南》,。要理解其為什么那么快又那么可靠又那么大存儲(chǔ)空間,。這同時(shí)也是理解冪等性最方便的系統(tǒng)。 (4)MySQL,,假裝也是中間件了,,推薦《MySQL高性能》,《MySQL 技術(shù)內(nèi)幕:InnoDB 存儲(chǔ)引擎》,。要了解紅黑樹和索引的實(shí)現(xiàn)方式,,了解 InnoDB 存儲(chǔ)引擎的工作原理,你才能更好的理解 explain sql 后出來的各種回顯結(jié)果,,從而幫助你更好的調(diào)優(yōu) SQL,。順便說一句 MyISAM 被廢棄了,,你可以少看一本書了,偷著樂吧,。 (5)nginx,。之所以能有多個(gè)冪等存在就全靠它了。學(xué)習(xí)一下它的單線程技術(shù),,明明是單線程卻能做到高性能,。nginx:我就是看不上你多線程,咋啦,?唯有真正理解計(jì)算機(jī)原理才能返璞歸真,。 (6)Netty,推薦《Netty 權(quán)威指南》,。在2002之前很多系統(tǒng)都是阻塞 IO,,隨后的幾年中計(jì)算機(jī)網(wǎng)絡(luò)突然提速了,這是為什么,?2002發(fā)布 JDK1.4,,2004年出現(xiàn) Netty,之前大量的計(jì)算機(jī)網(wǎng)絡(luò)性能都被阻塞在 IO 上沒有被釋放,,NIO 出現(xiàn)后大幅度提升了 IO 效率,。我猜測,在 JDK 支持了 NIO 之后,,Tomcat 等 web 容器很快跟進(jìn)升級,,于是全世界在硬件資源沒變的情況下網(wǎng)絡(luò)站點(diǎn)的并發(fā)響應(yīng)能力卻大福提升了。 (7)Flume,,一個(gè)日志收集傳輸系統(tǒng),。 (8)Protobuf,序列化也是性能中需要重點(diǎn)關(guān)注的地方,。 (9)Tomcat,,太有名了,學(xué)學(xué)其 classloader 設(shè)計(jì)思想,。 5,、JavaEE,一個(gè)名存實(shí)亡的企業(yè)級開發(fā)標(biāo)準(zhǔn),,大部分已經(jīng)被業(yè)界拋棄,,依然有用的知識,如 servlet,,JMX 等,。一個(gè)時(shí)代的落幕,唉,。 6,、編譯原理和操作系統(tǒng):我假設(shè)你上大學(xué)的時(shí)候?qū)W過了,,如果沒有學(xué)過,操作系統(tǒng)至少要讀一下,,推薦清華大學(xué)的本科教材,。 7、分布式數(shù)據(jù)庫體系架構(gòu),,需要掌握分庫分表,、異構(gòu)索引、數(shù)據(jù)庫主備等,。推薦讀一下阿里的 OceanBase,,《大規(guī)模分布式存儲(chǔ)系統(tǒng):原理解析與架構(gòu)實(shí)戰(zhàn)》。另外推薦一本《數(shù)據(jù)密集型系統(tǒng)設(shè)計(jì)》,,堪稱存儲(chǔ)設(shè)計(jì)的通史,。 8、Spring 和 Mybatis,,掌握使用,,能讀懂源碼更好了。 9,、UML 建模,,推薦《UML 用戶指南》。 階段三:化神這個(gè)階段是最難晉升的了,,多少開發(fā)者都被阻塞在這一步難以前進(jìn),。因?yàn)榧纫袚?dān)繁重的開發(fā)任務(wù),又要學(xué)習(xí)那么多的知識,,還要處理個(gè)人的生活,,打工人太難了。這些知識對你的提升又只是相加不是相乘的關(guān)系,。熬過去你就海闊天空化神了,。 這一階段你會(huì)發(fā)現(xiàn)學(xué)習(xí)曲線越來越陡峭了,你要掌握: 1,、架構(gòu)設(shè)計(jì)方法論,推薦《軟件架構(gòu)設(shè)計(jì)》,,教會(huì)你做事的章法,。 2、領(lǐng)域驅(qū)動(dòng)設(shè)計(jì),,推薦Eric 的《領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)》,,很晦澀不太容易懂。軟件是真實(shí)世界在計(jì)算機(jī)中的虛擬映射,,需要學(xué)習(xí)如何讓軟件更貼近真實(shí)世界,。 3,、中臺(tái):中臺(tái)這個(gè)詞近些年太火了,這個(gè)詞最早是阿里提出來的,,推薦找阿里的書讀一下,。 4、高性能調(diào)優(yōu):真正了解計(jì)算機(jī)的本質(zhì)才能做到性能調(diào)優(yōu),,推薦讀《性能之巔》,。 5、穩(wěn)定性建設(shè):推薦阿里的《逆流而上》,,這可不是小說,,主要講阿里巴巴集團(tuán)榮耀背后的技術(shù)血淚史,分享了一些典型的踩坑案例,。 6,、兩地三中心容災(zāi)系統(tǒng)建設(shè):這個(gè)主要靠實(shí)踐經(jīng)驗(yàn)了。 7,、全鏈路壓測:對系統(tǒng)的性能瓶頸節(jié)點(diǎn)的探查,,對系統(tǒng) QPS 的掌控。 8,、大數(shù)據(jù):離線海量數(shù)據(jù)存儲(chǔ)與計(jì)算的 Hadoop,,將 Hadoop 變得更易用的 Hive,流計(jì)算的 Flink,,自成一套的 ELK,,尤其是彈性搜索 ElasticSearch。 9,、數(shù)據(jù)倉庫:大數(shù)據(jù)都學(xué)了,,順便也把數(shù)倉也學(xué)了吧,順手的事,。 10,、網(wǎng)絡(luò)安全:這一塊我沒有涉足,不班門弄斧了,。 這一階段我對技術(shù)的介紹越來越粗了,,因?yàn)槟阒按虻幕A(chǔ)可以支撐去學(xué)習(xí)這些粗粒度的技術(shù),你也應(yīng)該有自己的學(xué)習(xí)方法了,,也能自己去找書學(xué)習(xí)了,。 階段四:渡劫經(jīng)過上面幾個(gè)階段的洗禮,你基本上已經(jīng)成為技術(shù)骨干,,組內(nèi)技術(shù)大牛,,但如果想在公司內(nèi)或者行業(yè)內(nèi)嶄露頭角,你需要在技術(shù)上再上一個(gè)臺(tái)階,。 1,、中間件實(shí)現(xiàn)細(xì)節(jié):隨著業(yè)務(wù)的快速發(fā)展,,一些開源中間件不能完全滿足要求,可能需要改造中間件,,甚至再造一個(gè)輪子,,你需要對中間件的實(shí)現(xiàn)細(xì)節(jié)了如指掌。 2,、再擴(kuò)展一下領(lǐng)域,,比如 AI 領(lǐng)域,需要有數(shù)學(xué)基礎(chǔ),,要了解各種論文與算法的實(shí)現(xiàn),。 3、也可以往 IOT 方向發(fā)展,,隨著5G 的發(fā)展,,這個(gè)領(lǐng)域我持續(xù)看好。 總結(jié)技術(shù)成長之路漫漫,,需要積累和堅(jiān)持,,相信終究有一日你可以飛升成仙成神。 - EOF - |
|