B“A”T大牛分享如何在最短的時間升職為阿里Java架構師
Java架構師是什麼?
要想往Java架構師的方向發展首先要知道Java架構師是什麼?
Java架構師是一個既需要掌控整體又需要洞悉區域性瓶頸並依據具體的業務場景給出解決方案的團隊領導型人物。一個Java架構師得需要足夠的想像力,能把各種目標需求進行不同維度的擴充套件,為目標客戶提供更為全面的需求清單。
Java架構師在軟體開發的整個過程中起著很重要的作用。說的詳細一些,架構師就是確認和評估系統需求,給出開發規範,搭建系統實現的核心構架,並澄清技術細節、掃清主要難點的技術人員。主要著眼於系統的“技術實現”。
架構師應不應該寫程式碼
為什麼別人的系統總是那麼爛
成為架構師最困難的門檻是什麼?
如何更高效的學習?
1.架構師應不應該寫程式碼
合格的程式員對於明確分配的任務會完成的很好,但是大部分情況下“架構”這個詞意味著架構師並不會涉及太多細節,架構圖和程式碼實現之間總還是有些距離,你無法保證所有人都會正確的理解你的設計,或者是程式設計師寫程式碼時遇到障礙時會立刻想出足夠優雅的解決方案。
在我看來,寫程式碼的架構師更像是在做後勤保障的工作:在程式碼中第一時間發現可能存在的問題,向其他人提出警告,或是給予其他人改進的意見,必要的時候或是給其他人演示一下正確的姿勢。
大部分情況下我作為架構師並不需要攬下“核心模組”開發這種工作,畢竟我能調配的時間太零散了,效率難以保證,很多人在專注的情況下比我做的好很多,我只需要保持大局觀需要適度參與就可以了。
總的來說,架構師和程式設計師在某些方面上有點像產品經理和使用者的關係,大部分程式設計師並不會主動告訴你他們想要什麼、哪裡需要優化,甚至自己也不知道這些。想要做出好的產品,捷徑之一就是跟使用者做同樣的事情。
2.為什麼別人的系統總是那麼爛
很多程式員解決問題的能力很強,說要解決一個什麼問題,下午就能寫出幾百行程式碼把功能實現了。但是做出來的東西有種少考慮了什麼東西的感覺。大部分程式都能實現功能,但是如果把“時間”這個也作為一個考慮的維度的話,就會意識到一個合格的專案需要考慮更多的東西:更通用的使用方式、易於理解的文件、簡單而易於擴充套件的設計,等等。
很多公司應該都會有一些遺留系統,它們龐大、笨重、難用、幾乎無法維護,所有人都在抱怨這些系統,並且每天都在想方設法換掉那些遺留系統。但是一段時間過去之後,又會發現身邊的新人又開始吐槽當時替代遺留系統的那個系統了。
“大多數系統當初都很好使,功能當時夠用,擴充套件性看起來也可以,但是這些系統都是開發的人離職之後變壞的。”
3.成為架構師最困難的門檻是什麼?
很多人自稱架構師的人跟你講一個架構時簡直滔滔不絕,各種技術名詞像是說相聲一樣從他嘴裡說出來,三句話不離高併發大資料,但是稍微追問一下,就會發現很多基本概念的缺失,例如自稱精通高併發的人說不清楚他所謂的高併發系統的瓶頸在哪裡,自稱精通架構設計的人說不明白他的系統怎麼保證高可用,自稱超大資料量的系統實際上只有不到100萬條資料,等等。
架構師雖然聽起來很高大上,但本質上仍然是工程師,不是科學家,也不是忽悠人的江湖騙子。學習再多,也需要實踐落地。設計架構方案更多的是在做一些抽象和權衡:把複雜的需求抽象成簡單的模型,從功能、效能、可用性、研發成本等等方面規劃如何構建一個系統,這些內容需要更多的實踐練習。
4.如何更高效的學習?
大多數人每天能留給自己學習的時間有限,這個階段如何提升學習效率就成了要解決的重點。
說說自己提升學習效率的心得,其實非常簡單:體系化的學習。
在重複了幾次痛苦的學習-梳理過程後,再去看一些獨立的文章或者資料往往會事半功倍,因為能在體系內找到相對應的知識,甚至有時候一本書裡一頁只需要看一句話,點破那層窗戶紙,就可以掌握新的知識。
跟很多人一樣,剛畢業時我覺得作為程式設計師,只要努力,加上少許天賦便可以獲得一些成績。
工作一段時間後,對自己和其他人的認識也越來越清晰,逐漸的發現程式設計師之間的差距或許比人和猴子之間的差距還大,接受這個事實這讓我鬱悶了很久。
再過一段時間,發現自己已經能夠客觀的評價自己的能力,也意識到了距離並不是那麼重要,只要想辦法跑的更快,就足夠了。
5.快速成為架構師的學習路線
分散式學習路線
1.常用架構原始碼分析
程式設計師每天都和程式碼打交道。經過數年的基礎教育和職業培訓,大部分程式設計師都會「寫」程式碼,或者至少會抄程式碼和改程式碼。但是,會讀程式碼的並不在多數,會讀程式碼又真正讀懂一些大專案的原始碼的,少之又少。這也造成了很多錯誤看原始碼的方式。

2.網際網路分散式架構專題
對上面的技術知識點感興趣的朋友們可以加我的Java後端架構學習群:795632998,進群即可免費獲取以上技術的學習資料。

. 3.團隊協作開發專題
應對複雜的業務需求變更、使用者膨脹,SOA已成為現在網際網路公司標準的解決方案,微服務相關的框架正是為此而生。

4.微服務專題
應對複雜的業務需求變更、使用者膨脹,SOA已成為現在網際網路公司標準的解決方案,微服務相關的框架正是為此而生。

5.效能調優專題

電商專案實戰
大型電商分散式系統應用實踐,利用雲伺服器搭建真實的開發和部署環境,千人線上參與開發。
由淺入深的,帶你從零到專案釋出上線與運維,讓你體驗真實的企業級專案開發過程,掌握大牛的編碼思維、經驗與技巧。

以上是我總結出來的這些年的知識路線,中途也有了解過其他的技術,也想過要轉其他的語言,但是最後還是堅持下來走Java這條路,希望我的經歷可以幫助到後來的人,要是覺得對你有幫助的話,可以點個喜歡。如果對上面的技術知識點感興趣的朋友們可以加我的Java後端架構學習群:795632998,進群即可免費獲取以上技術的學習資料。