更新時(shí)間:2019-08-06 10:29:29 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1903次
怎么樣成為java架構(gòu)師呢?相信這是很多java從業(yè)者,又或者說是coder/碼農(nóng)們比較感興趣的問題,要回答這個(gè)問題,首先需要明白的是java架構(gòu)師是什么?
簡單點(diǎn)說,java架構(gòu)師的主要任務(wù)不是從事具體的軟件程序的編寫,而是從事更高層次的開發(fā)構(gòu)架工作。主要著眼于系統(tǒng)的“技術(shù)實(shí)現(xiàn)”,工作內(nèi)容就是確認(rèn)和評估系統(tǒng)需求,給出開發(fā)規(guī)范,搭建系統(tǒng)實(shí)現(xiàn)的核心構(gòu)架,并澄清技術(shù)細(xì)節(jié)、掃清主要難點(diǎn)的技術(shù)人員,并且需要有良好的組織管理能力。因此應(yīng)該是特定的開發(fā)平臺、語言、工具的大師,對常見應(yīng)用場景能馬上給出最恰當(dāng)?shù)慕鉀Q方案,同時(shí)要對所屬的開發(fā)團(tuán)隊(duì)有足夠的了解,能夠評估自己的團(tuán)隊(duì)實(shí)現(xiàn)特定的功能需求需要的代價(jià)。 系統(tǒng)架構(gòu)師負(fù)責(zé)設(shè)計(jì)系統(tǒng)整體架構(gòu),從需求到設(shè)計(jì)的每個(gè)細(xì)節(jié)都要考慮到,把握整個(gè)項(xiàng)目,使設(shè)計(jì)的項(xiàng)目盡量效率高,開發(fā)容易,維護(hù)方便,升級簡單等。可以這樣說,一個(gè)java架構(gòu)師工作的好壞決定了整個(gè)軟件開發(fā)項(xiàng)目的成敗。
在成為Java架構(gòu)師之前,應(yīng)當(dāng)先成為Java工程師。熟練使用各種框架,并知道它們實(shí)現(xiàn)的原理。jvm虛擬機(jī)原理、調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;什么對象池,連接池,線程池……Java反射技術(shù),寫框架必備的技術(shù),遇到有嚴(yán)重的性能問題,替代方案java字節(jié)碼技術(shù);而Java學(xué)到極致勢必涉及到設(shè)計(jì)模式,算法和數(shù)據(jù)結(jié)構(gòu),多線程,文件及網(wǎng)絡(luò)IO,數(shù)據(jù)庫及ORM,不一而足。這些概念放之一切語言都適用。先精一門,為全面且不膚淺打基礎(chǔ)。
其實(shí)最重要的能力就是不斷學(xué)習(xí)。在思考新的技術(shù)是否能更好地解決你們遇到的問題之前,你首先得知道并了解新的技術(shù)。千萬不要成為不寫代碼的架構(gòu)師,有些公司專門產(chǎn)不寫技術(shù)的架構(gòu)師。所謂架構(gòu)師,只是功底深厚的程序員而已。個(gè)人認(rèn)為應(yīng)該扎扎實(shí)實(shí)學(xué)習(xí)基礎(chǔ)知識,學(xué)習(xí)各種規(guī)范,架構(gòu),需要廣泛的知識面,懂的東西越多視野越開闊,設(shè)計(jì)的東西當(dāng)然會(huì)越好越全面。成為架構(gòu)師需要時(shí)間的積累的,不但要知其然還要知其所以然。平時(shí)的一點(diǎn)一滴你感覺不到特別用處,但某天你會(huì)發(fā)現(xiàn)所有東西都沒有白學(xué)的。
下面是我總結(jié)多年經(jīng)驗(yàn)開發(fā)的架構(gòu)師知識體系
一、分布式架構(gòu)
架構(gòu)分布式的英文( Distributed computing 分布式計(jì)算技術(shù))的應(yīng)用和工具,成熟目前的技術(shù)包括 J2EE,CORBA 和 .NET(DCOM),這些技術(shù)牽扯的內(nèi)容非常廣,相關(guān)的書籍也非常多。
本文不介紹這些技術(shù)的內(nèi)容,也沒有涉及這些技術(shù)的細(xì)節(jié),只是從各種分布式系統(tǒng)平臺產(chǎn)生的背景和在軟件開發(fā)中應(yīng)用的情況來探討它們的主要異同。
分布式系統(tǒng)是一個(gè)古老而寬泛的話題,而近幾年因?yàn)?ldquo;大數(shù)據(jù)”概念的興起,又煥發(fā)出了新的青春與活力。
除此之外,分布式系統(tǒng)也是一門理論模型與工程技法。并重的學(xué)科內(nèi)容相比于機(jī)器學(xué)習(xí)這樣的研究方向,學(xué)習(xí)分布式系統(tǒng)的同學(xué)往往會(huì)感覺:“入門容易,深入難”的確,學(xué)習(xí)分布式系統(tǒng)幾乎不需要太多數(shù)學(xué)知識。
分布式系統(tǒng)是一個(gè)復(fù)雜且寬泛的研究領(lǐng)域,學(xué)習(xí)一兩門在線課程,看一兩本書可能都是不能完全覆蓋其所有內(nèi)容的。
總的來說,分布式系統(tǒng)要做的任務(wù)就是把多臺機(jī)器有機(jī)的組合,連接起來,讓其協(xié)同完成一件任務(wù),可以是計(jì)算任務(wù),也可以是存儲(chǔ)任務(wù)。
如果一定要給近些年的分布式系統(tǒng)研究做一個(gè)分類的話,我個(gè)人認(rèn)為大概可以包括三大部分:
1、分布式存儲(chǔ)系統(tǒng)
2、分布式計(jì)算系統(tǒng)
3、分布式管理系統(tǒng)
二、微服務(wù)
當(dāng)前微服務(wù)很熱,大家都號稱在使用微服務(wù)架構(gòu),但究竟什么是微服務(wù)架構(gòu)?微服務(wù)架構(gòu)是不是發(fā)展趨勢?對于這些問題,我們都缺乏清楚的認(rèn)識。
為解決單體架構(gòu)下的各種問題,微服務(wù)架構(gòu)應(yīng)運(yùn)而生。與其構(gòu)建一個(gè)臃腫龐大,難以馴服的怪獸,還不如及早將服務(wù)拆分。微服務(wù)的核心思想便是服務(wù)拆分與解耦,降低復(fù)雜性。
微服務(wù)強(qiáng)調(diào)將功能合理拆解,盡可能保證每個(gè)服務(wù)的功能單一,按照單一責(zé)任原則(Single Responsibility Principle)明確角色。將各個(gè)服務(wù)做輕,從而做到靈活,可復(fù)用,亦可根據(jù)各個(gè)服務(wù)自身資源需求,單獨(dú)布署,單獨(dú)作橫向擴(kuò)展。
微服務(wù)架構(gòu)(Microservice Architecture)是一種架構(gòu)概念,旨在通過將功能分解到各個(gè)離散的服務(wù)中以實(shí)現(xiàn)對解決方案的解耦。你可以將其看作是在架構(gòu)層次而非獲取服務(wù)的類上應(yīng)用很多 SOLID 原則。微服務(wù)架構(gòu)是個(gè)很有趣的概念,它的主要作用是將功能分解到離散的各個(gè)服務(wù)當(dāng)中,從而降低系統(tǒng)的耦合性,并提供更加靈活的服務(wù)支持。
概念:把一個(gè)大型的單個(gè)應(yīng)用程序和服務(wù)拆分為數(shù)個(gè)甚至數(shù)十個(gè)的支持微服務(wù),它可擴(kuò)展單個(gè)組件而不是整個(gè)的應(yīng)用程序堆棧,從而滿足服務(wù)等級協(xié)議。
定義:圍繞業(yè)務(wù)領(lǐng)域組件來創(chuàng)建應(yīng)用,這些應(yīng)用可獨(dú)立地進(jìn)行開發(fā),管理和迭代在分散的組件中使用云架構(gòu)和平臺式部署,管理和服務(wù)功能,使產(chǎn)品交付變得更加簡單。
本質(zhì):用一些功能比較明確,業(yè)務(wù)比較精練的服務(wù)去解決更大,更實(shí)際的問題。
三、源碼分析
從字面意義上來講,源文件的英文指一個(gè)文件,指源代碼的集合。源代碼則是一組具有特定意義的可以實(shí)現(xiàn)特定功能的字符(程序開發(fā)代碼)。
源碼分析是一種臨界知識,掌握了這種臨界知識,能不變應(yīng)萬變,源碼分析對于很多人來說很枯燥,生澀難懂。源碼閱讀,最核心有三點(diǎn):技術(shù)基礎(chǔ)+強(qiáng)烈的求知欲+耐心。
四、工具使用
工欲善其事必先利其器,工具對 Java 的的程序員的重要性不言而喻現(xiàn)在有很多庫,實(shí)用工具和程序任的 Java 的開發(fā)人員選擇。如Maven/Jenkins/Sonar/Git等。
五、性能優(yōu)化
不管是應(yīng)付前端面試還是改進(jìn)產(chǎn)品體驗(yàn),性能優(yōu)化都是躲不開的話題。優(yōu)化的目的是讓用戶有“快”的感受,那如何讓用戶感受到快呢?
加載速度真的很快,用戶打開輸入網(wǎng)址按下回車立即看到了頁面,加載速度并沒有變快,但用戶感覺你的網(wǎng)站很快,性能優(yōu)化取決于多個(gè)因素,包括垃圾收集,虛擬機(jī)和底層操作系統(tǒng)(OS)設(shè)置。有多個(gè)工具可供開發(fā)人員進(jìn)行分析和優(yōu)化時(shí)使用,你可以通過閱讀爪哇工具的源代碼優(yōu)化和分析來學(xué)習(xí)和使用它們。
必須要明白的是,沒有兩個(gè)應(yīng)用程序可以使用相同的優(yōu)化方式,也沒有完美的優(yōu)化的 Java 應(yīng)用程序的參考路徑。使用最佳實(shí)踐并且堅(jiān)持采用適當(dāng)?shù)姆绞教幚硇阅軆?yōu)化。想要達(dá)到真正最高的性能優(yōu)化,作為一個(gè) Java 的開發(fā)人員,需要對 Java 的虛擬機(jī)(JVM)和底層操作系統(tǒng)有正確的理解。
性能優(yōu)化,簡而言之,就是在不影響系統(tǒng)運(yùn)行正確性的前提下,使之運(yùn)行地更快,完成特定功能所需的時(shí)間更短。性能問題永遠(yuǎn)是永恒的主題之一,而優(yōu)化則更需要技巧。
Java程序員如何學(xué)習(xí)才能快速入門并精通呢?
當(dāng)真正開始學(xué)習(xí)的時(shí)候難免不知道從哪入手,導(dǎo)致效率低下影響繼續(xù)學(xué)習(xí)的信心。
但最重要的是不知道哪些技術(shù)需要重點(diǎn)掌握,學(xué)習(xí)時(shí)頻繁踩坑,最終浪費(fèi)大量時(shí)間,所以有一套實(shí)用的視頻課程用來跟著學(xué)習(xí)是非常有必要的。
為了讓學(xué)習(xí)變得輕松、高效,今天給大家免費(fèi)分享一套教學(xué)資源。幫助大家在成為架構(gòu)師的道路上披荊斬棘。
java免費(fèi)視頻教程鏈接:http://www.dabaquan.cn/video.html
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743