成爲一個高級Java架構師所須要具有那些技能呢?

成爲java架構師所須要具有那些技能?java


所謂架構師,思考的是全局的東西,是如何組織你的系統,以達到業務要求,性能要求,具有可擴展性(scalability),可拓展性(extendability),先後兼容性等。可能涉及到的東西包括了從硬件到軟件的方方面面,實在是一言難盡。mysql


既然java架構師,首先你要是一個高級java攻獅城,熟練使用各類框架,並知道它們實現的原理。jvm虛擬機原理、調優,懂得jvm能讓你寫出性能更好的代碼;池技術,什麼對象池,鏈接池,線程池…:;java反射技術,寫框架必備的技術,可是有嚴重的性能問題,替代方案java字節碼技術;nio,沒什麼好說的,值得注意的是"直接內存"的特色,使用場景;java多線程同步異步;java各類集合對象的實現原理,瞭解這些可讓你在解決問題時選擇合適的數據結構,高效的解決問題,好比hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有爲什擴容時有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會認爲本身作的很對;總之一句話越基礎的東西越重要,不少人認爲本身會用它們寫代碼了,其實僅僅是知道如何調用api而已,離會用還差的遠。linux


熟練使用各類數據結構和算法,數組、哈希、鏈表、排序樹…,一句話要麼是時間換空間要麼是空間換時間,這裏展開能夠說一大堆,須要有必定的應用經驗,用於解決各類性能或業務上的問題。nginx


熟練使用linux操做系統,必備,沒什麼好說的。redis


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


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


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


分佈式緩存技術memcached,redis,提升系統性能必備,一句話,把硬盤上的內容放到內存裏來提速,順便提個算法一致性hash。數據庫


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


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


還有隊列中間件。如消息推送,能夠先把消息寫入數據庫,推送放隊列服務器上,由推送服務器去隊列獲取處理,這樣就能夠將消息放數據庫和隊列裏後直接給用戶反饋,推送過程則由推送服務器和隊列服務器完成,好處異步處理、緩解服務器壓力,解藕系統。


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


架構師還要針對業務特色、系統的性能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人用戶的系統,訪問量不大,數據量小,你給人家上集羣、上分佈式存儲、上高端服務器,爲了架構而架構,這是最扯淡的,架構師的做用就是第一知足業務需求,第二最低的硬件網絡成本和技術維護成本。


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


架構之路任重而道遠。程序設計和架構設計是互通的,每一個人均可以從設計好一個程序往設計好一個系統架構前進。若是如今還無從下手的,我推薦你們能夠從領域驅動設計這個概念入手,這是由業務爲導向的設計方式,能夠對培養設計出落地的架構有很大的幫助。你們能夠加羣:458462877一塊兒交流,羣裏也會定時分享一些java架構的知識,但願能夠給你們一些思路和啓發。最後引用「俞軍」一句名言,咱們做爲架構師要有「懷疑精神:自我迭代」的心。

相關文章
相關標籤/搜索