如何從Java程序員到架構(gòu)師-晉升篇

如何從Java程序員到架構(gòu)師-晉升篇

北大青鳥(niǎo)長(zhǎng)沙麓谷校區(qū)      2022-04-06 02:35:01     8

如何從Java程序員到架構(gòu)師-晉升篇,  如何從Java程序員到架構(gòu)師?首先你要先是一個(gè)Java程序員,熟練使用各種框架,并知道它們實(shí)現(xiàn)的原理。jvm虛擬機(jī)原理、調(diào)優(yōu),

課程價(jià)格 請(qǐng)咨詢

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

  如何從Java程序員到架構(gòu)師?首先你要先是一個(gè)Java程序員,熟練使用各種框架,并知道它們實(shí)現(xiàn)的原理。jvm虛擬機(jī)原理、調(diào)優(yōu),懂得jvm能讓你寫(xiě)出性能更好的代碼;池技術(shù),什么對(duì)象池,怎么解決并發(fā)量、連接池,線程池。


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


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



  技術(shù)歸納


  熟練使用linux操作系統(tǒng),必備,沒(méi)什么好說(shuō)的。


  熟悉tcp協(xié)議,創(chuàng)建連接三次握手和斷開(kāi)連接四次握手的整個(gè)過(guò)程,不了解的話,無(wú)法對(duì)高并發(fā)網(wǎng)絡(luò)應(yīng)用做優(yōu)化;熟悉http協(xié)議,尤其是http頭,我發(fā)現(xiàn)好多工作五年以上的都弄不清session和cookie的生命周期以及它們之間的關(guān)聯(lián)。


  系統(tǒng)集群、負(fù)載均衡、反向代理、動(dòng)靜分離,網(wǎng)站靜態(tài)化。


  分布式存儲(chǔ)系統(tǒng)nfs,fastdfs,tfs,Hadoop了解他們的優(yōu)缺點(diǎn),適用場(chǎng)景。


  分布式緩存技術(shù)memcached,redis,提高系統(tǒng)性能必備,一句話,把硬盤上的內(nèi)容放到內(nèi)存里來(lái)提速,順便提個(gè)算法一致性hash。


  工具nginx必備技能超級(jí)好用,高性能,基本不會(huì)掛掉的服務(wù)器,功能多多,解決各種問(wèn)題。


  數(shù)據(jù)庫(kù)的設(shè)計(jì)能力,mysql必備,最基礎(chǔ)的數(shù)據(jù)庫(kù)工具,免費(fèi)好用,對(duì)它基本的參數(shù)優(yōu)化,慢查詢?nèi)罩痉治觯鲝膹?fù)制的配置,至少要成為半個(gè)mysqldba。其他nosql數(shù)據(jù)庫(kù)如mongodb。


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



  面試方面


  企業(yè)應(yīng)用的系統(tǒng)架構(gòu)師應(yīng)該關(guān)注的幾個(gè)方面(具體情況具體分析,以下未必準(zhǔn)確,只是參考)


  先來(lái)一些Java基礎(chǔ)面試題,您答得出么?


  1、說(shuō)說(shuō)JVM原理??jī)?nèi)存泄露與溢出區(qū)別,何時(shí)產(chǎn)生內(nèi)存泄露?


  2、用java怎么實(shí)現(xiàn)有每天有1億條記錄的DB存儲(chǔ)?mysql上億記錄數(shù)據(jù)量的數(shù)據(jù)庫(kù)如何設(shè)計(jì)?


  3、mysql支持事務(wù)嗎?DB存儲(chǔ)引擎有哪些?


  4、mvc原理,mvc模式的優(yōu)缺點(diǎn),如果讓你設(shè)計(jì)你會(huì)怎么改造MVC?


  5、hibernate支持集群?jiǎn)??如何?shí)現(xiàn)集群?


  6、tomcat最多支持并發(fā)多少用戶?


  7、map原理,它是如何快速查找key的?map與set區(qū)別?


  8、描術(shù)算法,如何有效合并兩個(gè)文件:一個(gè)是1億條的用戶基本信息,另一個(gè)是用戶每天看電影連續(xù)劇等的記錄,5000萬(wàn)條。內(nèi)存只有1G???


  9、在1億條用戶記錄里,如何快速查詢統(tǒng)計(jì)出看了5個(gè)電影以上的用戶?----可以參考位圖索引的原理


  10、Spring如何實(shí)現(xiàn)IOC與AOP的,說(shuō)出實(shí)現(xiàn)原理?


  以上純粹是常用的技術(shù),還有很多自己慢慢去摸索吧;因?yàn)橐赖臇|西很多,所以要成為一名合格的架構(gòu)師,必須要有強(qiáng)大的自學(xué)能力,沒(méi)有人會(huì)手把手的教給你所有的東西。


  想成為架構(gòu)師不是懂了一大堆技術(shù)就可以了,這些是解決問(wèn)題的基礎(chǔ)、是工具,不懂這些怎么去提解決方案呢?這是成為架構(gòu)師的必要條件。


  架構(gòu)師要針對(duì)業(yè)務(wù)特點(diǎn)、系統(tǒng)的性能要求提出能解決問(wèn)題成本最低的設(shè)計(jì)方案才合格,人家一個(gè)幾百人用戶的系統(tǒng),訪問(wèn)量不大,數(shù)據(jù)量小,你給人家上集群、上分布式存儲(chǔ)、上高端服務(wù)器,為了架構(gòu)而架構(gòu),這是最扯淡的,架構(gòu)師的作用就是第一滿足業(yè)務(wù)需求,第二最低的硬件網(wǎng)絡(luò)成本和技術(shù)維護(hù)成本。


  架構(gòu)師還要根據(jù)業(yè)務(wù)發(fā)展階段,提前預(yù)見(jiàn)發(fā)展到下一個(gè)階段系統(tǒng)架構(gòu)的解決方案,并且設(shè)計(jì)當(dāng)前架構(gòu)時(shí)將架構(gòu)的升級(jí)擴(kuò)展考慮進(jìn)去,做到易于升級(jí);否則等系統(tǒng)瓶頸來(lái)了,出問(wèn)題了再去出方案,或現(xiàn)有架構(gòu)無(wú)法擴(kuò)展直接扔掉重做,或擴(kuò)展麻煩問(wèn)題一大堆,這會(huì)對(duì)企業(yè)造成損失。


  


培訓(xùn)啦提醒您:交易時(shí)請(qǐng)核實(shí)對(duì)方資質(zhì),對(duì)于過(guò)大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。