溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java架構(gòu)師需要哪些知識?

發(fā)布時間:2020-05-29 20:33:01 來源:億速云 閱讀:244 作者:鴿子 欄目:編程語言

如何才能達到Java架構(gòu)師技術(shù)要求標(biāo)準(zhǔn)?Java架構(gòu)師需要熟練掌握復(fù)雜的數(shù)據(jù)結(jié)構(gòu)和算法、熟練使用linux操作系統(tǒng),Linux線上排除故障、熟悉tcp協(xié)議、系統(tǒng)集群、負載均衡、反向代理、動靜分離,網(wǎng)站靜態(tài)化、數(shù)據(jù)庫設(shè)計能力隊列中間件等知識。

 

Java架構(gòu)師需要哪些知識?

 

一、高級Java工程師掌握的基礎(chǔ)

 

熟練使用各種框架以及實現(xiàn)的原理、JVM虛擬機原理、JVM調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;池技術(shù):什么對象池連接池,線程池;Java反射技術(shù),寫框架必備的技術(shù)。

 

Java各種集合對象的實現(xiàn)原理,了解這些可以讓你在解決問題時選擇合適的數(shù)據(jù)結(jié)構(gòu),高效的解決問題,比如hashmap的實現(xiàn)原理,好多五年以上經(jīng)驗的人都弄不清楚,還有為什擴容時有性能問題?不弄清楚這些原理寫不出高效的代碼。越基礎(chǔ)的東西越重要,僅知道如何調(diào)用api離會用還差的遠。

 

二、復(fù)雜的數(shù)據(jù)結(jié)構(gòu)和算法

 

熟練使用各種數(shù)據(jù)結(jié)構(gòu)和算法,數(shù)組、哈希、鏈表、排序樹...,一句話要么是時間換空間要么是空間換時間,這里展開可以說一大堆,需要有一定的應(yīng)用經(jīng)驗,用于解決各種性能或業(yè)務(wù)上的問題。

 

三、熟練使用linux操作系統(tǒng)

 

linux操作系統(tǒng),Linux線上排除故障,以及性能監(jiān)控等。

 

四、熟悉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慢查詢?nèi)罩痉治?,主從?fù)制的配置,至少要成為半個mysqldba。其他nosql數(shù)據(jù)庫mongodb

 

七、隊列中間件

 

消息推送,可以先把消息寫入數(shù)據(jù)庫,推送放隊列服務(wù)器上,由推送服務(wù)器去隊列獲取處理,這樣就可以將消息放數(shù)據(jù)庫和隊列里后直接給用戶反饋,推送過程則由推送服務(wù)器和隊列服務(wù)器完成,好處異步處理、緩解服務(wù)器壓力,解藕系統(tǒng)。

 

常用的技術(shù)有需要自己摸索學(xué)習(xí),要成為一名合格的架構(gòu)師,要有強大的自學(xué)能力。

 

八、服務(wù)業(yè)務(wù)

 

架構(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è)造成損失。

 

Java架構(gòu)師要根據(jù)業(yè)務(wù)發(fā)展階段,提前預(yù)見發(fā)展到下一個階段系統(tǒng)架構(gòu)的解決方案,設(shè)計當(dāng)前架構(gòu)時將架構(gòu)的升級擴展考慮進去,做到易于升級。滿足業(yè)務(wù)需求的同時用最低的硬件網(wǎng)絡(luò)成本和技術(shù)維護成本。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI