什么是架構(gòu)設(shè)計(jì),怎樣可以做好構(gòu)架設(shè)計(jì)?

架構(gòu)設(shè)計(jì)是軟件設(shè)計(jì)過(guò)程的早期階段,它把需求分析和設(shè)計(jì)流程連接在一起。架構(gòu)師的主要任務(wù)不是從事具體的軟件程序的編寫(xiě),而是從事更高層次的開(kāi)發(fā)構(gòu)架工作。他架構(gòu)設(shè)計(jì)不一定要有架構(gòu)師的頭銜。擁有架構(gòu)師頭銜的人不一定了解架構(gòu)設(shè)計(jì),也不一定有機(jī)會(huì)真正參與架構(gòu)設(shè)計(jì)。對(duì)于程序員來(lái)說(shuō),即使沒(méi)有架構(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ù),就無(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ì)重用思維

重用是提高開(kāi)發(fā)效率最簡(jiǎn)單有效的方法。通過(guò)抽象相同的內(nèi)容,它可以在不同的場(chǎng)景中重用。很多新手程序喜歡復(fù)制粘貼代碼,如果需求發(fā)生變化,需要修改所有粘貼的地方,開(kāi)發(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)滿足開(kā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)域,降低開(kāi)發(fā)難度

3、分層設(shè)計(jì),隔離業(yè)務(wù)邏輯,減少需求變化的影響

四、架構(gòu)設(shè)計(jì)為什么存在

1、需求使技術(shù)復(fù)雜化。例如一個(gè)博客和一個(gè)谷歌,技術(shù)上的復(fù)雜性是不一樣的

2、人們使技術(shù)復(fù)雜化。軟件開(kāi)發(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ù)雜。軟件開(kāi)發(fā)完成上線后,充滿了各種不確定性,比如云服務(wù)提供商可能宕機(jī)、明星微博導(dǎo)致系統(tǒng)癱瘓、數(shù)據(jù)庫(kù)刪除等

基于以上原因,我們需要架構(gòu)設(shè)計(jì)來(lái)降低復(fù)雜性

1、降低開(kāi)發(fā)成本。將復(fù)雜的系統(tǒng)劃分為幾個(gè)相對(duì)簡(jiǎn)單的服務(wù),可以由普通程序員來(lái)完成,降低了人工成本。

2、幫助組織高效地工作。通過(guò)抽象和拆分,開(kāi)發(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ì),前端和后端分離,以及合適的開(kāi)發(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ì)更像是一門(mén)內(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)注創(chuàng)新互聯(lián)!

當(dāng)前題目:什么是架構(gòu)設(shè)計(jì),怎樣可以做好構(gòu)架設(shè)計(jì)?
當(dāng)前網(wǎng)址:http://muchs.cn/article12/sdsodc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、標(biāo)簽優(yōu)化面包屑導(dǎo)航、網(wǎng)站內(nèi)鏈、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)