Java架構(gòu)師需要學(xué)習(xí)的東西

? ? ? ? 既然java架構(gòu)師,首先你要是一個高級java攻城尸,熟練使用各種框架,并知道它們實現(xiàn)的原理。

? ? ? ? ? jvm虛擬機原理、調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;池技術(shù),什么對象池,連接池,線程池...:;java反射技術(shù),寫框架必備的技術(shù),但是有嚴重的性能問題,替代方案java字節(jié)碼技術(shù);nio,沒什么好說的,值得注意的是"直接內(nèi)存"的特點,使用場景;java多線程同步異步;java各種集合對象的實現(xiàn)原理,了解這些可以讓你在解決問題時選擇合適的數(shù)據(jù)結(jié)構(gòu),高效的解決問題,比如hashmap的實現(xiàn)原理,好多五年以上經(jīng)驗的人都弄不清楚,還有為什擴容時有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會認為自己做的很對;總之一句話越基礎(chǔ)的東西越重要,很多人認為自己會用它們寫代碼了,其實僅僅是知道如何調(diào)用api而已,離會用還差的遠。

? ? ? ? ?熟練使用各種數(shù)據(jù)結(jié)構(gòu)和算法,數(shù)組、哈希、鏈表、排序樹...,一句話要么是時間換空間要么是空間換時間,這里展開可以說一大堆,需要有一定的應(yīng)用經(jīng)驗,用于解決各種性能或業(yè)務(wù)上的問題;有時間再補充。熟練使用linux操作系統(tǒng),必備,沒什么好說的 。熟悉tcp協(xié)議,創(chuàng)建連接三次握手和斷開連接四次握手的整個過程,不了解的話,無法對高并發(fā)網(wǎng)絡(luò)應(yīng)用做優(yōu)化; 熟悉http協(xié)議,尤其是http頭,我發(fā)現(xiàn)好多工作五年以上的都弄不清session和cookie的生命周期以及它們之間的關(guān)聯(lián)。系統(tǒng)集群、負載均衡、反向代理、動靜分離,網(wǎng)站靜態(tài)化 。分布式存儲系統(tǒng)nfs,fastdfs,tfs,Hadoop了解他們的優(yōu)缺點,適用場景 。分布式緩存技術(shù)memcached,redis,提高系統(tǒng)性能必備,一句話,把硬盤上的內(nèi)容放到內(nèi)存里來提速,順便提個算法一致性hash 。工具nginx必備技能超級好用,高性能,基本不會掛掉的服務(wù)器,功能多多,解決各種問題。數(shù)據(jù)庫的設(shè)計能力,mysql必備,最基礎(chǔ)的數(shù)據(jù)庫工具,免費好用,對它基本的參數(shù)優(yōu)化,慢查詢?nèi)罩痉治觯鲝膹?fù)制的配置,至少要成為半個mysql dba。其他nosql數(shù)據(jù)庫如mongodb。還有隊列中間件。如消息推送,可以先把消息寫入數(shù)據(jù)庫,推送放隊列服務(wù)器上,由推送服務(wù)器去隊列獲取處理,這樣就可以將消息放數(shù)據(jù)庫和隊列里后直接給用戶反饋,推送過程則由推送服務(wù)器和隊列服務(wù)器完成,好處異步處理、緩解服務(wù)器壓力,解藕系統(tǒng)。

? ? ? ? ? 以上純粹是常用的技術(shù),還有很多自己慢慢去摸索吧;因為要知道的東西很多,所以要成為一名合格的架構(gòu)師,必須要有強大的自學(xué)能力,沒有人會手把手的教給你所有的東西。想成為架構(gòu)師不是懂了一大堆技術(shù)就可以了,這些是解決問題的基礎(chǔ)、是工具,不懂這些怎么去提解決方案呢?這是成為架構(gòu)師的必要條件。

? ? ? ? ? 架構(gòu)師還要針對業(yè)務(wù)特點、系統(tǒng)的性能要求提出能解決問題成本最低的設(shè)計方案才合格,人家一個幾百人用戶的系統(tǒng),訪問量不大,數(shù)據(jù)量小,你給人家上集群、上分布式存儲、上高端服務(wù)器,為了架構(gòu)而架構(gòu),這是最扯淡的,架構(gòu)師的作用就是第一滿足業(yè)務(wù)需求,第二最低的硬件網(wǎng)絡(luò)成本和技術(shù)維護成本。架構(gòu)師還要根據(jù)業(yè)務(wù)發(fā)展階段,提前預(yù)見發(fā)展到下一個階段系統(tǒng)架構(gòu)的解決方案,并且設(shè)計當(dāng)前架構(gòu)時將架構(gòu)的升級擴展考慮進去,做到易于升級;否則等系統(tǒng)瓶頸來了,出問題了再去出方案,或現(xiàn)有架構(gòu)無法擴展直接扔掉重做,或擴展麻煩問題一大堆,這會對企業(yè)造成損失;手機手工輸入的,想到哪里寫到哪里,很亂..做技術(shù)的,表達能力不強,將就著看吧,歡迎大家補充,歡迎有多年工作經(jīng)驗的Java大神——群587372254互相學(xué)習(xí)交流,有學(xué)習(xí)有交流才有進步。

? ? ? ? ? 所謂架構(gòu)師,思考的是全局的東西,是如何組織你的系統(tǒng),以達到業(yè)務(wù)要求,性能要求,具備可擴展性(scalability),可拓展性(extendability),前后兼容性等。可能涉及到的東西包括了從硬件到軟件的方方面面,實在是一言難盡。如果你立志做架構(gòu),首先打好基礎(chǔ),從最底層開始。然后發(fā)展到各種技術(shù)和語言,什么都要懂兩點,要全面且不膚淺。為什么不是懂一點?你要看得透徹,必須盡量深入一些。別人懂一點,你要做架構(gòu)師,必須再多懂一點。比如你發(fā)現(xiàn)golang很流行,別人可能寫一個helloworld就說自己玩過golang,但你至少要嘗試寫一個完整的應(yīng)用。不肯下苦功,如何高人一頭?另外你要非常深入地了解至少一門語言,如果你的目標是java,就學(xué)到極致,作為敲門磚,先吃飽了才能談理想。而Java學(xué)到極致勢必涉及到設(shè)計模式,算法和數(shù)據(jù)結(jié)構(gòu),多線程,文件及網(wǎng)絡(luò)IO,數(shù)據(jù)庫及ORM,不一而足。這些概念放之一切語言都適用。先精一門,為全面且不膚淺打基礎(chǔ)。另外就是向有經(jīng)驗的架構(gòu)師學(xué)習(xí),和小伙伴們討論辯論爭論。其實最重要的能力就是不斷學(xué)習(xí)。在思考新的技術(shù)是否能更好地解決你們遇到的問題之前,你首先得知道并了解新的技術(shù)。說了半天,架構(gòu)師很多時候是被迫上位的,并不是你學(xué)了這個和那個之后你就成為架構(gòu)師了,這并不是RPG游戲。

1:扎實的java基礎(chǔ)。如樓上的寫的看過thinking in java??梢允且幻细竦某绦騿T

2:熟練使用基本的框架。比如ssh,shiro等等。這時應(yīng)該可以稱之為軟件工程師了

3:有過2中框架或者web中間件的源碼研究經(jīng)歷。

4:經(jīng)歷過大并發(fā)挑戰(zhàn),并且有過相關(guān)應(yīng)對經(jīng)驗

5:有消息中間件,服務(wù)中間件等的使用和架構(gòu)經(jīng)驗

6:對系統(tǒng)本身的業(yè)務(wù)特點有深刻的理解。能夠針對業(yè)務(wù)特點,分析短板并解決。

實例分析:一例千萬級pv高性能高并發(fā)網(wǎng)站架構(gòu)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容