1. 程式人生 > >Java程式設計師該如何突破瓶頸,成長為優秀的架構師

Java程式設計師該如何突破瓶頸,成長為優秀的架構師

一、如何定義架構師

Java架構師,首先要是一個Java程式設計師,熟練掌握使用各種框架,並知道它們實現的原理,Java虛擬機器原理、調優,懂得JVM能讓你寫出效能更好的程式碼,池技術,什麼物件池,怎麼解決併發量、連線池,執行緒池。

Java反射技術,寫框架必備的技術,但是有嚴重的效能問題,代替方案Java位元組碼技術nio,沒什麼好說的,值得注意的是“直接記憶體”的特點,使用場景Java多執行緒同步非同步Java各種集合物件的實現原理,瞭解這些可以讓你在解決問題時選擇合適的資料結構,高效的解決問題,比如hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有為什麼擴容時有效能問題?不弄清楚這些原理,就寫不出高效的程式碼,好會認為自己做的很對,總之一句話越基礎的東西越要,很對人認為自己會用它們寫程式碼了。其實僅僅是知道如何呼叫api而已,離會用還差的遠。

640?wx_fmt=jpeg&wxfrom=5&wx_lazy=1

二、技術歸納

熟練使用linux作業系統,必備,沒什麼好說的 。

熟悉tcp協議,建立連線三次握手和斷開連線四次握手的整個過程,不瞭解的話,無法對高併發網路應用做優化; 熟悉http協議,尤其是http頭,我發現好多工作五年以上的都弄不清session和cookie的生命週期以及它們之間的關聯。

系統叢集、負載均衡、反向代理、動靜分離,網站靜態化 。

分散式儲存系統nfs,fastdfs,tfs,Hadoop瞭解他們的優缺點,適用場景 。

分散式快取技術memcached,redis,提高系統性能必備,一句話,把硬碟上的內容放到記憶體裡來提速,順便提個演算法一致性hash 。

工具nginx必備技能超級好用,高效能,基本不會掛掉的伺服器,功能多多,解決各種問題。

資料庫的設計能力,mysql必備,最基礎的資料庫工具,免費好用,對它基本的引數優化,慢查詢日誌分析,主從複製的配置,至少要成為半個mysql dba。其他nosql資料庫如mongodb。

還有佇列中介軟體。如訊息推送,可以先把訊息寫入資料庫,推送放佇列伺服器上,由推送伺服器去佇列獲取處理,這樣就可以將訊息放資料庫和佇列裡後直接給使用者反饋,推送過程則由推送伺服器和佇列伺服器完成,好處非同步處理、緩解伺服器壓力,解藕系統。

三、面試方面

企業應用的系統架構師應該關注的幾個方面 (具體情況具體分析,以下未必準確,只是參考)

先來一些基礎面試題,您答得出麼?

1、說說JVM原理?記憶體洩露與溢位區別,何時產生記憶體洩露?

2、用java怎麼實現有每天有1億條記錄的DB儲存?mysql上億記錄資料量的資料庫如何設計?

3、mysql支援事務嗎?DB儲存引擎有哪些?

4、mvc原理,mvc模式的優缺點,如果讓你設計你會怎麼改造MVC?

5、hibernate支援叢集嗎?如何實現叢集?

6、tomcat 最多支援併發多少使用者?

7、map原理,它是如何快速查詢key的?map與set區別?

8、描術演算法,如何有效合併兩個檔案:一個是1億條的使用者基本資訊,另一個是使用者每天看電影連續劇等的記錄,5000萬條。記憶體只有1G???

9、在1億條使用者記錄裡,如何快速查詢統計出看了5個電影以上的使用者? ----可以參考 點陣圖索引的原理

10、Spring如何實現IOC與AOP的,說出實現原理?

以上純粹是常用的技術,還有很多自己慢慢去摸索吧;因為要知道的東西很多,所以要成為一名合格的架構師,必須要有強大的自學能力,沒有人會手把手的教給你所有的東西。

想成為架構師不是懂了一大堆技術就可以了,這些是解決問題的基礎、是工具,不懂這些怎麼去提解決方案呢?這是成為架構師的必要條件。

架構師要針對業務特點、系統的效能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人使用者的系統,訪問量不大,資料量小,你給人家上叢集、上分散式儲存、上高階伺服器,為了架構而架構,這是最扯淡的,架構師的作用就是第一滿足業務需求,第二最低的硬體網路成本和技術維護成本。

架構師還要根據業務發展階段,提前預見發展到下一個階段系統架構的解決方案,並且設計當前架構時將架構的升級擴充套件考慮進去,做到易於升級;否則等系統瓶頸來了,出問題了再去出方案,或現有架構無法擴充套件直接扔掉重做,或擴充套件麻煩問題一大堆,這會對企業造成損失。

在此分享一份自己收藏的適合2-5年Java程式設計師學習的架構路線圖:

640?wx_fmt=jpeg

640?wx_fmt=png

640?wx_fmt=png

https://blog.csdn.net/t4i2b10X4c22nF6A/article/details/80223267