成為java架構師需要具備那些技能?

來源:互聯網
上載者:User
架構師定義
百度百科,系統架構師是一個既需要掌控整體又需要洞悉局部瓶頸並依據具體的業務情境給出解決方案的團隊領導型人物。
架構師工作職能
軟體架構師在整個軟體開發過程中都起著重要的作用,並隨著開發進程的推進而其職責或關注點不斷地變化,在需求階段,軟體架構師主要負責理解和管理非功能性系統需求,比如軟體的可維護性、效能、複用性、可靠性、有效性和可測試性等等,此外,架構師還要經常審查客戶及市場人員所提出的需求,確認Team Dev所提出的設計;在需求越來越明確後,架構師的關注點開始轉移到組織Team Dev成員和開發流程定義上;在軟體設計階段,架構師負責對整個軟體體繫結構、關鍵構件、介面和開發政策的設計;在編碼階段,架構師則成為詳細設計者和代碼編寫者的顧問,並且經常性地要舉行一些技術研討會、技術培訓班等;隨著軟體開始測試、整合和交付,整合和測試支援將成為軟體架構師的工作重點;在軟體維護開始時,軟體架構師就開始為下一版本的產品是否應該增加新的功能模組進行決策。
成為java架構師所需要具備那些技能。
所謂架構師,思考的是全域的東西,是如何組織你的系統,以達到業務要求,效能要求,具備可擴充性(scalability),可拓展性(extendability),前後相容性等。可能涉及到的東西包括了從硬體到軟體的方方面面,實在是一言難盡。
既然java架構師,首先你要是一個進階java攻獅城,熟練使用各種架構,並知道它們實現的原理。jvm虛擬機器原理、調優,懂得jvm能讓你寫出效能更好的代碼;池技術,什麼對象池,串連池,線程池...:;java反射技術,寫架構必備的技術,但是有嚴重的效能問題,替代方案java位元組碼技術;nio,沒什麼好說的,值得注意的是"直接記憶體"的特點,使用情境;java多線程同步非同步;java各種集合對象的實現原理,瞭解這些可以讓你在解決問題時選擇合適的資料結構,高效的解決問題,比如hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有為什擴容時有效能問題。不弄清楚這些原理,就寫不出高效的代碼,還會認為自己做的很對;總之一句話越基礎的東西越重要,很多人認為自己會用它們寫代碼了,其實僅僅是知道如何調用api而已,離會用還差的遠。
熟練使用各種資料結構和演算法,數組、雜湊、鏈表、排序樹...,一句話要麼是時間換空間要麼是空間換時間,這裡展開可以說一大堆,需要有一定的應用經驗,用於解決各種效能或業務上的問題。
熟練使用linux作業系統,必備,沒什麼好說的。
熟悉tcp協議,建立串連三向交握和中斷連線四次握手的整個過程,不瞭解的話,無法對高並髮網絡應用做最佳化;熟悉http協議,尤其是http頭,我發現好多工作五年以上的都弄不清session和cookie的生命週期以及它們之間的關聯。
系統叢集、負載平衡、反向 Proxy、動靜分離,網站靜態化。
分布式儲存系統nfs,fastdfs,tfs,Hadoop瞭解他們的優缺點,適用情境。
分布式緩衝技術memcached,redis,提高系統效能必備,一句話,把硬碟上的內容放到記憶體裡來提速,順便提個演算法一致性hash。
工具nginx必備技能超級好用,高效能,基本不會掛掉的伺服器,功能多多,解決各種問題。
資料庫的設計能力,mysql必備,最基礎的資料庫工具,免費好用,對它基本的參數最佳化,慢查詢日誌分析,主從複製的配置,至少要成為半個mysqldba。其他nosql資料庫如mongodb。
還有隊列中介軟體。如訊息推送,可以先把訊息寫入資料庫,推送放佇列服務器上,由推送伺服器去隊列擷取處理,這樣就可以將訊息放資料庫和隊列裡後直接給使用者反饋,推送過程則由推送伺服器和佇列服務器完成,好處非同步處理、緩解伺服器壓力,解藕系統。
想成為架構師不是懂了一大堆技術就可以了,這些是解決問題的基礎、是工具,不懂這些怎麼去提解決方案呢。這是成為架構師的必要條件。
架構師還要針對業務特點、系統的效能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人使用者的系統,訪問量不大,資料量小,你給人家上叢集、上分布式儲存、上高端伺服器,為了架構而架構,這是最扯淡的,架構師的作用就是第一滿足業務需求,第二最低的硬體網路成本和技術維護成本。
架構師還要根據業務發展階段,提前預見發展到下一個階段系統架構的解決方案,並且設計當前架構時將架構的升級擴充考慮進去,做到易於升級;否則等系統瓶頸來了,出問題了再去出方案,或現有架構無法擴充直接扔掉重做,或擴充麻煩問題一大堆,這會對企業造成損失。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.