架構(gòu)設(shè)計(jì)是軟件設(shè)計(jì)過程的早期階段,它把需求分析和設(shè)計(jì)流程連接在一起。架構(gòu)師的主要任務(wù)不是從事具體的軟件程序的編寫,而是從事更高層次的開發(fā)構(gòu)架工作。他架構(gòu)設(shè)計(jì)不一定要有架構(gòu)師的頭銜。擁有架構(gòu)師頭銜的人不一定了解架構(gòu)設(shè)計(jì),也不一定有機(jī)會(huì)真正參與架構(gòu)設(shè)計(jì)。對(duì)于程序員來說,即使沒有架構(gòu)師的頭銜,我們也可以很好地練習(xí)架構(gòu)設(shè)計(jì)技巧。下面就由
創(chuàng)新互聯(lián)建站小編和大家講一講什么是架構(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ù),就無法做好適合業(yè)務(wù)的架構(gòu)設(shè)計(jì),行業(yè)的相關(guān)知識(shí)也無法在短時(shí)間內(nèi)積累。
3、良好的溝通能力。架構(gòu)師需要溝通和確認(rèn)需求,團(tuán)隊(duì)需要理解架構(gòu)設(shè)計(jì)。
4、有結(jié)構(gòu)性思維。知道如何使用抽象、分而治之、重用、迭代等思想來降低軟件復(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)分為小部分和簡單部分。例如,對(duì)于高并發(fā)場景,可以通過設(shè)計(jì)將流量劃分為不同的服務(wù)器,以避免單個(gè)服務(wù)器過載。另一個(gè)例子是將一個(gè)1000行函數(shù)封裝成n個(gè)不超過50行的獨(dú)立函數(shù)調(diào)用
3、構(gòu)架設(shè)計(jì)重用思維
重用是提高開發(fā)效率最簡單有效的方法。通過抽象相同的內(nèi)容,它可以在不同的場景中重用。很多新手程序喜歡復(fù)制粘貼代碼,如果需求發(fā)生變化,需要修改所有粘貼的地方,開發(fā)效率低,維護(hù)困難,同時(shí)也浪費(fèi)了大量的測試精力。
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ì)就是用最小的人力成本來滿足開發(fā)和需求變化的需要,用最小的運(yùn)行成本來保證軟件的運(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ì),成員的水平不一樣,擅長的技術(shù)方向也不一樣,如何有效的合作是一個(gè)很大的考驗(yàn)。
一元廣告投放3、技術(shù)本身是復(fù)雜的。軟件項(xiàng)目中使用的編程語言、框架、組件、數(shù)據(jù)庫、人工智能、大數(shù)據(jù)等技術(shù)都有學(xué)習(xí)成本
4、軟件的穩(wěn)定運(yùn)行也很復(fù)雜。軟件開發(fā)完成上線后,充滿了各種不確定性,比如云服務(wù)提供商可能宕機(jī)、明星微博導(dǎo)致系統(tǒng)癱瘓、數(shù)據(jù)庫刪除等
基于以上原因,我們需要架構(gòu)設(shè)計(jì)來降低復(fù)雜性
1、降低開發(fā)成本。將復(fù)雜的系統(tǒng)劃分為幾個(gè)相對(duì)簡單的服務(wù),可以由普通程序員來完成,降低了人工成本。
2、幫助組織高效地工作。通過抽象和拆分,開發(fā)人員可以獨(dú)立完成功能模塊。
3、組織各種技術(shù)。選擇合適的編程語言、協(xié)議、框架、組件等來達(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)品需求,分析用例,了解各種用戶角色及其使用場景
2、選擇類似成熟的架構(gòu)設(shè)計(jì)。例如,微服務(wù)架構(gòu)設(shè)計(jì),前端和后端分離,以及合適的開發(fā)語言和框架應(yīng)該根據(jù)團(tuán)隊(duì)來選擇。
3、從上到下。好的做法是自上而下,不要過早進(jìn)入技術(shù)細(xì)節(jié),從整體到局部規(guī)劃,設(shè)計(jì)部署架構(gòu),分層和分模塊,API設(shè)計(jì),數(shù)據(jù)庫設(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ù)增長的時(shí)間,如半年或一年或三年。
5、架構(gòu)設(shè)計(jì)需要有戰(zhàn)略眼光,不僅要有架構(gòu)理念,還要有不同場景的架構(gòu)實(shí)踐,還要吸取以往的實(shí)踐經(jīng)驗(yàn)。架構(gòu)設(shè)計(jì)更像是一門內(nèi)功,需要不斷修煉,才能應(yīng)對(duì)各種場景的挑戰(zhàn)。
與建筑學(xué)類似,如果軟件系統(tǒng)沒有一個(gè)好的架構(gòu)是不可能成為成功的軟件系統(tǒng)的。沒有圖紙的建筑地、沒有設(shè)計(jì)的造橋工程都是不可以想象的混亂世界。建筑工程如是,軟件工程中亦然!小伙伴們要想獲得更多架構(gòu)設(shè)計(jì)的內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)!
當(dāng)前名稱:什么是架構(gòu)設(shè)計(jì),怎樣可以做好構(gòu)架設(shè)計(jì)?
文章URL:
http://weahome.cn/article/sdsodc.html