更新時間:2019-07-28 09:00:00 來源:動力節(jié)點 瀏覽2794次
如何從Java程序員到架構(gòu)師?首先你要先是一個Java程序員,熟練使用各種框架,并知道它們實現(xiàn)的原理。jvm虛擬機原理、調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;池技術(shù),什么對象池,怎么解決并發(fā)量、連接池,線程池。
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ù)組、哈希、鏈表、排序樹…,一句話要么是時間換空間要么是空間換時間,這里展開可以說一大堆,需要有一定的應用經(jīng)驗,用于解決各種性能或業(yè)務上的問題。
技術(shù)歸納
熟練使用linux操作系統(tǒng),必備,沒什么好說的。
熟悉tcp協(xié)議,創(chuàng)建連接三次握手和斷開連接四次握手的整個過程,不了解的話,無法對高并發(fā)網(wǎ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必備技能超級好用,高性能,基本不會掛掉的服務器,功能多多,解決各種問題。
數(shù)據(jù)庫的設(shè)計能力,mysql必備,最基礎(chǔ)的數(shù)據(jù)庫工具,免費好用,對它基本的參數(shù)優(yōu)化,慢查詢?nèi)罩痉治觯鲝膹椭频呐渲茫辽僖蔀榘雮€mysqldba。其他nosql數(shù)據(jù)庫如mongodb。
還有隊列中間件。如消息推送,可以先把消息寫入數(shù)據(jù)庫,推送放隊列服務器上,由推送服務器去隊列獲取處理,這樣就可以將消息放數(shù)據(jù)庫和隊列里后直接給用戶反饋,推送過程則由推送服務器和隊列服務器完成,好處異步處理、緩解服務器壓力,解藕系統(tǒng)。
面試方面
企業(yè)應用的系統(tǒng)架構(gòu)師應該關(guān)注的幾個方面(具體情況具體分析,以下未必準確,只是參考)
先來一些Java基礎(chǔ)面試題,您答得出么?
1、說說JVM原理?內(nèi)存泄露與溢出區(qū)別,何時產(chǎn)生內(nèi)存泄露?
2、用java怎么實現(xiàn)有每天有1億條記錄的DB存儲?mysql上億記錄數(shù)據(jù)量的數(shù)據(jù)庫如何設(shè)計?
3、mysql支持事務嗎?DB存儲引擎有哪些?
4、mvc原理,mvc模式的優(yōu)缺點,如果讓你設(shè)計你會怎么改造MVC?
5、hibernate支持集群嗎?如何實現(xiàn)集群?
6、tomcat最多支持并發(fā)多少用戶?
7、map原理,它是如何快速查找key的?map與set區(qū)別?
8、描術(shù)算法,如何有效合并兩個文件:一個是1億條的用戶基本信息,另一個是用戶每天看電影連續(xù)劇等的記錄,5000萬條。內(nèi)存只有1G???
9、在1億條用戶記錄里,如何快速查詢統(tǒng)計出看了5個電影以上的用戶?----可以參考位圖索引的原理
10、Spring如何實現(xiàn)IOC與AOP的,說出實現(xiàn)原理?
以上純粹是常用的技術(shù),還有很多自己慢慢去摸索吧;因為要知道的東西很多,所以要成為一名合格的架構(gòu)師,必須要有強大的自學能力,沒有人會手把手的教給你所有的東西。
想成為架構(gòu)師不是懂了一大堆技術(shù)就可以了,這些是解決問題的基礎(chǔ)、是工具,不懂這些怎么去提解決方案呢?這是成為架構(gòu)師的必要條件。
架構(gòu)師要針對業(yè)務特點、系統(tǒng)的性能要求提出能解決問題成本最低的設(shè)計方案才合格,人家一個幾百人用戶的系統(tǒng),訪問量不大,數(shù)據(jù)量小,你給人家上集群、上分布式存儲、上高端服務器,為了架構(gòu)而架構(gòu),這是最扯淡的,架構(gòu)師的作用就是第一滿足業(yè)務需求,第二最低的硬件網(wǎng)絡成本和技術(shù)維護成本。
架構(gòu)師還要根據(jù)業(yè)務發(fā)展階段,提前預見發(fā)展到下一個階段系統(tǒng)架構(gòu)的解決方案,并且設(shè)計當前架構(gòu)時將架構(gòu)的升級擴展考慮進去,做到易于升級;否則等系統(tǒng)瓶頸來了,出問題了再去出方案,或現(xiàn)有架構(gòu)無法擴展直接扔掉重做,或擴展麻煩問題一大堆,這會對企業(yè)造成損失。