架構(gòu)師定義
百度百科,系統(tǒng)架構(gòu)師是一個(gè)既需要掌控整體又需要洞悉局部瓶頸并依據(jù)具體的業(yè)務(wù)場景給出解決方案的團(tuán)隊(duì)領(lǐng)導(dǎo)型人物。
架構(gòu)師工作職能
軟件架構(gòu)師在整個(gè)軟件開發(fā)過程中都起著重要的作用,并隨著開發(fā)進(jìn)程的推進(jìn)而其職責(zé)或關(guān)注點(diǎn)不斷地變化,在需求階段,軟件架構(gòu)師主要負(fù)責(zé)理解和管理非功能性系統(tǒng)需求,比如軟件的可維護(hù)性、性能、復(fù)用性、可靠性、有效性和可測試性等等,此外,架構(gòu)師還要經(jīng)常審查客戶及市場人員所提出的需求,確認(rèn)開發(fā)團(tuán)隊(duì)所提出的設(shè)計(jì);在需求越來越明確后,架構(gòu)師的關(guān)注點(diǎn)開始轉(zhuǎn)移到組織開發(fā)團(tuán)隊(duì)成員和開發(fā)過程定義上;在軟件設(shè)計(jì)階段,架構(gòu)師負(fù)責(zé)對整個(gè)軟件體系結(jié)構(gòu)、關(guān)鍵構(gòu)件、接口和開發(fā)政策的設(shè)計(jì);在編碼階段,架構(gòu)師則成為詳細(xì)設(shè)計(jì)者和代碼編寫者的顧問,并且經(jīng)常性地要舉行一些技術(shù)研討會(huì)、技術(shù)培訓(xùn)班等;隨著軟件開始測試、集成和交付,集成和測試支持將成為軟件架構(gòu)師的工作重點(diǎn);在軟件維護(hù)開始時(shí),軟件架構(gòu)師就開始為下一版本的產(chǎn)品是否應(yīng)該增加新的功能模塊進(jìn)行決策。
高級java架構(gòu):656039503 大家一起進(jìn)群討論技術(shù) 交流學(xué)習(xí)里面有真正的大牛直播指點(diǎn) 前提要求就是基礎(chǔ)不能差 講的都有高級進(jìn)階的知識 包括架構(gòu) 下面是里面的一小部分章節(jié) 有興趣 有基礎(chǔ)的來
成為java架構(gòu)師所需要具備那些技能?
所謂架構(gòu)師,思考的是全局的東西,是如何組織你的系統(tǒng),以達(dá)到業(yè)務(wù)要求,性能要求,具備可擴(kuò)展性(scalability),可拓展性(extendability),前后兼容性等。可能涉及到的東西包括了從硬件到軟件的方方面面,實(shí)在是一言難盡。
既然java架構(gòu)師,首先你要是一個(gè)高級java攻獅城,熟練使用各種框架,并知道它們實(shí)現(xiàn)的原理。jvm虛擬機(jī)原理、調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;池技術(shù),什么對象池,連接池,線程池…:;java反射技術(shù),寫框架必備的技術(shù),但是有嚴(yán)重的性能問題,替代方案java字節(jié)碼技術(shù);nio,沒什么好說的,值得注意的是”直接內(nèi)存”的特點(diǎn),使用場景;java多線程同步異步;java各種集合對象的實(shí)現(xiàn)原理,了解這些可以讓你在解決問題時(shí)選擇合適的數(shù)據(jù)結(jié)構(gòu),高效的解決問題,比如hashmap的實(shí)現(xiàn)原理,好多五年以上經(jīng)驗(yàn)的人都弄不清楚,還有為什擴(kuò)容時(shí)有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會(huì)認(rèn)為自己做的很對;總之一句話越基礎(chǔ)的東西越重要,很多人認(rèn)為自己會(huì)用它們寫代碼了,其實(shí)僅僅是知道如何調(diào)用api而已,離會(huì)用還差的遠(yuǎn)。
熟練使用各種數(shù)據(jù)結(jié)構(gòu)和算法,數(shù)組、哈希、鏈表、排序樹…,一句話要么是時(shí)間換空間要么是空間換時(shí)間,這里展開可以說一大堆,需要有一定的應(yīng)用經(jīng)驗(yàn),用于解決各種性能或業(yè)務(wù)上的問題。
熟練使用linux操作系統(tǒng),必備,沒什么好說的。
熟悉tcp協(xié)議,創(chuàng)建連接三次握手和斷開連接四次握手的整個(gè)過程,不了解的話,無法對高并發(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)化。
分布式存儲系統(tǒng)nfs,fastdfs,tfs,Hadoop了解他們的優(yōu)缺點(diǎn),適用場景。
分布式緩存技術(shù)memcached,redis,提高系統(tǒng)性能必備,一句話,把硬盤上的內(nèi)容放到內(nèi)存里來提速,順便提個(gè)算法一致性hash。
工具nginx必備技能超級好用,高性能,基本不會(huì)掛掉的服務(wù)器,功能多多,解決各種問題。
數(shù)據(jù)庫的設(shè)計(jì)能力,mysql必備,最基礎(chǔ)的數(shù)據(jù)庫工具,免費(fèi)好用,對它基本的參數(shù)優(yōu)化,慢查詢?nèi)罩痉治觯鲝膹?fù)制的配置,至少要成為半個(gè)mysqldba。其他nosql數(shù)據(jù)庫如mongodb。
還有隊(duì)列中間件。如消息推送,可以先把消息寫入數(shù)據(jù)庫,推送放隊(duì)列服務(wù)器上,由推送服務(wù)器去隊(duì)列獲取處理,這樣就可以將消息放數(shù)據(jù)庫和隊(duì)列里后直接給用戶反饋,推送過程則由推送服務(wù)器和隊(duì)列服務(wù)器完成,好處異步處理、緩解服務(wù)器壓力,解藕系統(tǒng)。
想成為架構(gòu)師不是懂了一大堆技術(shù)就可以了,這些是解決問題的基礎(chǔ)、是工具,不懂這些怎么去提解決方案呢?這是成為架構(gòu)師的必要條件。
架構(gòu)師還要針對業(yè)務(wù)特點(diǎn)、系統(tǒng)的性能要求提出能解決問題成本最低的設(shè)計(jì)方案才合格,人家一個(gè)幾百人用戶的系統(tǒng),訪問量不大,數(shù)據(jù)量小,你給人家上集群、上分布式存儲、上高端服務(wù)器,為了架構(gòu)而架構(gòu),這是最扯淡的,架構(gòu)師的作用就是第一滿足業(yè)務(wù)需求,第二最低的硬件網(wǎng)絡(luò)成本和技術(shù)維護(hù)成本。
架構(gòu)師還要根據(jù)業(yè)務(wù)發(fā)展階段,提前預(yù)見發(fā)展到下一個(gè)階段系統(tǒng)架構(gòu)的解決方案,并且設(shè)計(jì)當(dāng)前架構(gòu)時(shí)將架構(gòu)的升級擴(kuò)展考慮進(jìn)去,做到易于升級;否則等系統(tǒng)瓶頸來了,出問題了再去出方案,或現(xiàn)有架構(gòu)無法擴(kuò)展直接扔掉重做,或擴(kuò)展麻煩問題一大堆,這會(huì)對企業(yè)造成損失。