什么是架構(gòu)設(shè)計(jì),怎樣可以做好構(gòu)架設(shè)計(jì)?
??一、好的架構(gòu)設(shè)計(jì)師有什么特點(diǎn)
??1、技術(shù)不錯(cuò)。至少代碼易于閱讀,易于擴(kuò)展,并且具有良好的重用性,這不僅需要學(xué)習(xí)面向?qū)ο蠛驮O(shè)計(jì)模式,還需要大量的編碼實(shí)踐,而不僅僅是紙上談兵
??2、了解業(yè)務(wù)。如果不了解業(yè)務(wù),就無(wú)法做好適合業(yè)務(wù)的架構(gòu)設(shè)計(jì),行業(yè)的相關(guān)知識(shí)也無(wú)法在短時(shí)間內(nèi)積累。
??3、良好的溝通能力。架構(gòu)師需要溝通和確認(rèn)需求,團(tuán)隊(duì)需要理解架構(gòu)設(shè)計(jì)。
??4、有結(jié)構(gòu)性思維。知道如何使用抽象、分而治之、重用、迭代等思想來(lái)降低軟件復(fù)雜性
??二、什么是架構(gòu)設(shè)計(jì)思維
??降低軟件復(fù)雜性有幾種有效的方法:抽象、分治、重用和迭代。架構(gòu)設(shè)計(jì)思維就是這些的集合
??1、構(gòu)架設(shè)計(jì)抽象思維
??體系結(jié)構(gòu)的存在是為了滿足業(yè)務(wù)需求。它通常需要一些文字描述、原型和UI設(shè)計(jì)圖,這些最終將成為機(jī)器執(zhí)行的代碼。我們必須首先把需求抽象成計(jì)算機(jī)可以識(shí)別的模型。例如,抽象用戶、訂單、內(nèi)容等模型,明確每個(gè)角色的職責(zé)和對(duì)象交互方式,隱藏很多不重要的細(xì)節(jié)。
??2、構(gòu)架設(shè)計(jì)分而治之思維
??復(fù)雜系統(tǒng)分為小部分和簡(jiǎn)單部分。例如,對(duì)于高并發(fā)場(chǎng)景,可以通過(guò)設(shè)計(jì)將流量劃分為不同的服務(wù)器,以避免單個(gè)服務(wù)器過(guò)載。另一個(gè)例子是將一個(gè)1000行函數(shù)封裝成n個(gè)不超過(guò)50行的獨(dú)立函數(shù)調(diào)用
??3、構(gòu)架設(shè)計(jì)重用思維
??重用是提高開發(fā)效率最簡(jiǎn)單有效的方法。通過(guò)抽象相同的內(nèi)容,它可以在不同的場(chǎng)景中重用。很多新手程序喜歡復(fù)制粘貼代碼,如果需求發(fā)生變化,需要修改所有粘貼的地方,開發(fā)效率低,維護(hù)困難,同時(shí)也浪費(fèi)了大量的測(cè)試精力。
??4、構(gòu)架設(shè)計(jì)迭代思維
??良好的體系結(jié)構(gòu)是不斷發(fā)展的。一步到位的架構(gòu)設(shè)計(jì)很少。我們需要確保業(yè)務(wù)的正常進(jìn)展不受影響,然后逐步迭代到最終合理的架構(gòu)設(shè)計(jì)
??三、什么是架構(gòu)設(shè)計(jì)
??架構(gòu)設(shè)計(jì)就是用最小的人力成本來(lái)滿足開發(fā)和需求變化的需要,用最小的運(yùn)行成本來(lái)保證軟件的運(yùn)行。常用方法如下:
??1、采用微服務(wù)體系架構(gòu)設(shè)計(jì),將復(fù)雜的系統(tǒng)劃分為一系列的小服務(wù),再劃分為功能模塊,使人員能夠更好地工作
??2、前端和后端分離,使程序員能夠?qū)W⒂谀骋恢R(shí)領(lǐng)域,降低開發(fā)難度
??3、分層設(shè)計(jì),隔離業(yè)務(wù)邏輯,減少需求變化的影響
??四、架構(gòu)設(shè)計(jì)為什么存在
??1、需求使技術(shù)復(fù)雜化。例如一個(gè)博客和一個(gè)谷歌,技術(shù)上的復(fù)雜性是不一樣的
??2、人們使技術(shù)復(fù)雜化。軟件開發(fā)是一個(gè)團(tuán)隊(duì),成員的水平不一樣,擅長(zhǎng)的技術(shù)方向也不一樣,如何有效的合作是一個(gè)很大的考驗(yàn)。
??3、技術(shù)本身是復(fù)雜的。軟件項(xiàng)目中使用的編程語(yǔ)言、框架、組件、數(shù)據(jù)庫(kù)、人工智能、大數(shù)據(jù)等技術(shù)都有學(xué)習(xí)成本
??4、軟件的穩(wěn)定運(yùn)行也很復(fù)雜。軟件開發(fā)完成上線后,充滿了各種不確定性,比如云服務(wù)提供商可能宕機(jī)、明星微博導(dǎo)致系統(tǒng)癱瘓、數(shù)據(jù)庫(kù)刪除等
??基于以上原因,我們需要架構(gòu)設(shè)計(jì)來(lái)降低復(fù)雜性
??1、降低開發(fā)成本。將復(fù)雜的系統(tǒng)劃分為幾個(gè)相對(duì)簡(jiǎn)單的服務(wù),可以由普通程序員來(lái)完成,降低了人工成本。
??2、幫助組織高效地工作。通過(guò)抽象和拆分,開發(fā)人員可以獨(dú)立完成功能模塊。
??3、組織各種技術(shù)。選擇合適的編程語(yǔ)言、協(xié)議、框架、組件等來(lái)達(dá)到最高效的要求
??4、保證服務(wù)的穩(wěn)定運(yùn)行。使用成熟的架構(gòu)設(shè)計(jì)解決方案,如負(fù)載平衡、限流、降級(jí)、融合等,確保服務(wù)的高可用性。
??五、怎樣做好架構(gòu)設(shè)計(jì)
??架構(gòu)設(shè)計(jì)需要很多經(jīng)驗(yàn),但我們可以站在巨人的肩膀上,在成熟架構(gòu)設(shè)計(jì)的基礎(chǔ)上,把它改造成適合自己業(yè)務(wù)需求的架構(gòu)設(shè)計(jì)
??1、分析需求。抽象產(chǎn)品需求,分析用例,了解各種用戶角色及其使用場(chǎng)景
??2、選擇類似成熟的架構(gòu)設(shè)計(jì)。例如,微服務(wù)架構(gòu)設(shè)計(jì),前端和后端分離,以及合適的開發(fā)語(yǔ)言和框架應(yīng)該根據(jù)團(tuán)隊(duì)來(lái)選擇。
??3、從上到下。好的做法是自上而下,不要過(guò)早進(jìn)入技術(shù)細(xì)節(jié),從整體到局部規(guī)劃,設(shè)計(jì)部署架構(gòu),分層和分模塊,API設(shè)計(jì),數(shù)據(jù)庫(kù)設(shè)計(jì)等。
??4、驗(yàn)證和優(yōu)化架構(gòu)設(shè)計(jì)。一個(gè)完整的體系結(jié)構(gòu)設(shè)計(jì)方案需要多次評(píng)審,充分收集各方面的反饋,反復(fù)修改后才能確定。此外,它還需要考慮架構(gòu)預(yù)計(jì)能滿足業(yè)務(wù)增長(zhǎng)的時(shí)間,如半年或一年或三年。
??5、架構(gòu)設(shè)計(jì)需要有戰(zhàn)略眼光,不僅要有架構(gòu)理念,還要有不同場(chǎng)景的架構(gòu)實(shí)踐,還要吸取以往的實(shí)踐經(jīng)驗(yàn)。架構(gòu)設(shè)計(jì)更像是一門內(nèi)功,需要不斷修煉,才能應(yīng)對(duì)各種場(chǎng)景的挑戰(zhàn)。
??與建筑學(xué)類似,如果軟件系統(tǒng)沒(méi)有一個(gè)好的架構(gòu)是不可能成為成功的軟件系統(tǒng)的。沒(méi)有圖紙的建筑地、沒(méi)有設(shè)計(jì)的造橋工程都是不可以想象的混亂世界。建筑工程如是,軟件工程中亦然!小伙伴們要想獲得更多架構(gòu)設(shè)計(jì)的內(nèi)容,請(qǐng)關(guān)注新網(wǎng)!
聲明:免責(zé)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),也不承認(rèn)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)本社區(qū)中有涉嫌抄襲的內(nèi)容,請(qǐng)發(fā)
送郵件至:operations@xinnet.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。本站原創(chuàng)內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)
需注明出處:新網(wǎng)idc知識(shí)百科