日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

軟件架構(architecture)是指軟件系統的基本結構以及創建這種結構和系統的規程。每個結構都包含軟件元素、它們之間的關系以及元素和關系的屬性。[1]軟件系統的架構是一個隱喻,類似于建筑物的架構。[2]它作為系統和開發項目的藍圖,布置設計團隊需要執行的任務。[3]

軟件架構(architecture)是指做出基本的結構選擇,一旦實現,改變這些選擇的代價是高昂的。軟件架構(architecture)選擇包括軟件設計中可能出現的特定結構選項。例如,控制航天飛機運載火箭的系統要求非常快和非常可靠。因此,需要選擇合適的實時計算語言。此外,為了滿足可靠性的需要,可以選擇有多個冗余和獨立生成的程序副本,并在交叉檢查結果的同時在獨立硬件上運行這些副本。

記錄軟件架構有助于利益相關者之間的溝通,捕獲有關高級設計的早期決策,并允許在項目之間重用設計組件。

范圍

對于軟件架構的范圍,人們的看法各不相同:[5]

  • 宏觀系統結構:這是指體系結構,它是一個軟件系統的高級抽象,由一組計算組件和描述這些組件之間交互的連接器組成。[6]
  • 不管是什么重要的東西:這指的是軟件架構師應該關注那些對系統及其涉眾有重大影響的決策。[7]
  • 對理解一個系統在其環境中所處的環境至關重要的東西[8]
  • 人們認為很難改變的事情:由于設計架構發生在軟件系統生命周期的開始,所以架構師應該關注那些“必須”在第一時間正確的決策。按照這種思路,一旦建筑設計問題的不可逆性能夠被克服,它們就可能變成非建筑性的問題
  • 一組架構設計決策:軟件體系結構不應僅僅被視為一組模型或結構,而應包括導致這些特定結構的決策及其背后的理論基礎。[9]這種見解導致了對軟件體系結構知識管理的大量研究。[10]

軟件架構(architecture)與設計(design)和需求工程(requirement engineering)之間沒有明顯的區別(參見下面的相關字段)。它們都是從高層意圖到底層細節的“意向鏈”的一部分

特點

軟件架構展示了以下內容:

  • 利益相關者眾多:軟件系統必須迎合各種利益相關者,如業務經理、所有者、用戶和運營商。這些利益相關者對系統都有自己的關注點。平衡這些關注點并證明它們得到了解決是系統設計的一部分。[4]:29–31這意味著體系結構涉及到處理各種各樣的關注點和涉眾,并且具有多學科性質。
  • 關注點分離:架構師降低復雜性的既定方法是分離驅動設計的關注點。架構(Architecture)文檔顯示,所有涉眾關注點都是通過從與各種涉眾關注點相關聯的不同角度建模和描述架構來解決的。[12]這些單獨的描述稱為架構視圖(例如,請參見4+1架構視圖模型)。
  • 質量驅動:經典的軟件設計方法(如Jackson結構化編程)是由系統所需的功能和數據流驅動的,但目前的觀點[4]:26-28是軟件系統的架構與其質量屬性(如容錯性、向后兼容性)的關系更為密切,可擴展性、可靠性、可維護性、可用性、安全性、可用性和其他此類功能。干系人關注點通常轉化為對這些質量屬性的需求,這些屬性被不同地稱為非功能需求、額外功能需求、行為需求或質量屬性需求。
  • 重復樣式:與構建架構一樣,軟件架構規程已經開發了解決重復問題的標準方法。這些“標準方法”在不同的抽象層次上由不同的名稱來調用。重復性解決方案的常用術語是架構樣式,[11]:273–277策略,[4]:70–72參考架構[13][14]和架構模式。[4]:203–205
  • 概念完整性:Fred Brooks在《神話人月》中引入的一個術語,用來表示軟件系統的架構代表了它應該做什么以及應該如何做的總體構想。這一設想應與實施分開。架構師承擔著“視覺守護者”的角色,確保系統的添加與體系結構一致,從而保持概念的完整性。[15]:41–50
  • 認知約束:計算機程序員Melvin Conway在1967年的一篇論文中首次觀察到,設計系統的組織被限制生成設計,這些設計是這些組織的通信結構的副本。與概念完整性一樣,弗雷德·布魯克斯在其優雅的經典作品《神話人月》(Mythical Man Month)中引用了這篇論文和這一理念,并稱之為“康威定律”(Conway's Law),將其介紹給了更廣泛的讀者

 

動機

軟件架構(architecture)是復雜系統的“智能可理解”抽象。[4]:5–6該抽象提供了許多好處:

  • 它為在系統構建之前對軟件系統的行為進行分析提供了基礎。[2]驗證未來軟件系統是否滿足其利益相關者的需求而無需實際構建它的能力代表了大量的成本節約和風險緩解。[16]已經開發了許多技術來執行此類分析,比如阿塔姆。
  • 它為元素和決策的重用提供了基礎。[2][4]:35一個完整的軟件體系結構或其部分,如單個體系結構策略和決策,可以跨多個系統重用,這些系統的涉眾需要相似的質量屬性或功能,從而節省設計成本并降低設計錯誤的風險。
  • 它支持影響系統開發、部署和維護壽命的早期設計決策。[4]:31正確地做出早期、高影響的決策對于防止進度和預算超支非常重要。
  • 它促進了與涉眾的溝通,有助于建立一個更好地滿足其需求的系統。[4]:29–31從涉眾的角度溝通復雜系統,有助于他們理解所述需求的后果以及基于這些需求的設計決策。體系結構使得在系統實現之前就設計決策進行交流的能力,而這些決策仍然相對容易適應。
  • 它有助于風險管理。軟件架構有助于減少風險和失敗的機會
  • 它可以降低成本。軟件架構是在復雜的IT項目中管理風險和成本的一種手段

歷史

軟件設計和(民用)建筑的比較最早出現在20世紀60年代末,[18] 但是直到20世紀90年代,“軟件體系結構”這個術語才被廣泛使用。[19]計算機科學領域自形成以來就遇到了與復雜性相關的問題。[20]早期的復雜性問題是由開發人員通過選擇正確的數據結構、開發算法和應用關注點分離。雖然“軟件架構”這個術語對業界來說是相對較新的,但自20世紀80年代中期以來,該領域的基本原理就被軟件工程的先驅們零星地應用。早期捕獲和解釋系統的軟件架構的嘗試是不精確和無序的,通常以一組方框圖和折線圖為特征。[21]

軟件體系結構作為一個概念起源于1968年Edsger Dijkstra和70年代早期David Parnas的研究,這些科學家強調軟件系統的結構至關重要,正確的結構至關重要。在20世紀90年代,有一個共同的努力來定義和編纂該學科的基本方面,研究工作集中在建筑風格(模式)、建筑描述語言、建筑文檔和形式方法上

作為一門學科,研究機構在促進軟件體系結構的發展方面發揮了突出的作用。卡內基梅隆大學的Mary Shaw和David Garlan在1996年寫了一本書,名為《軟件架構:對一門新興學科的展望》,該書提倡軟件架構概念,如組件、連接器和樣式。加州大學歐文軟件研究所致力于軟件架構研究,主要針對架構風格、架構描述語言和動態架構。

IEEE 1471-2000《軟件密集型系統體系結構描述推薦規程》是軟件體系結構領域的第一個正式標準。它于2007年被ISO采用為ISO/IEC 42010:2007。2011年11月,IEEE 1471-2000被ISO/IEC/IEEE 42010:2011“系統和軟件工程-架構描述”(由IEEE和ISO聯合發布)取代

在IEEE 1471中,軟件架構是關于“軟件密集型系統”的架構,定義為“軟件對整個系統的設計、構建、部署和演化產生重要影響的任何系統”,2011年版更進一步,包括了ISO/IEC 15288和ISO/IEC 12207對系統的定義,這些定義不僅包括硬件和軟件,還包括“人、過程、程序、設施、材料和自然發生的實體”。這反映了軟件架構、企業架構和解決方案架構之間的關系

架構活動

軟件架構師執行的活動有很多。軟件架構師通常與項目經理合作,與干系人討論架構上重要的需求,設計軟件架構,評估設計,與設計師和干系人溝通,記錄體系結構設計等。[23]軟件體系結構設計中有四個核心活動。[24]這些核心體系結構活動是在初始軟件開發生命周期的不同階段以及系統的演化過程中迭代執行的。

  • 架構(architecture)分析是理解所提議的系統將在其中運行的環境并確定系統需求的過程。分析活動的輸入或需求可以來自任何數量的涉眾,包括以下項目:
  1. 系統運行時將做什么(功能需求
  2. 系統將如何執行運行時非功能性需求,如可靠性、可操作性、性能效率、安全性、ISO/IEC 25010:2011標準[25]中定義的兼容性
  3. 開發時非功能性需求,如ISO 25010:2011標準[25]中定義的可維護性和可轉移性
  4. 一個系統的業務需求和環境背景可能會隨著時間而改變,例如法律、社會、金融、競爭和技術問題[26]
  • 分析活動的輸出是那些對軟件系統架構有可測量影響的需求,稱為架構上重要的需求
  • 架構綜合或設計是創造一個架構的過程。考慮到通過分析確定的架構上的重要需求、設計的當前狀態和任何評估活動的結果,創建并改進了設計。[24][4]:311–326
  • 架構(Architecture)評估(evaluation)是確定當前設計或其一部分如何滿足分析期間導出的需求的過程。每當架構師考慮設計決策時,評估就可能發生,評估可能發生在設計的某一部分完成之后,評估可能發生在最終設計完成之后,評估也可能發生在系統構建之后。一些可用的軟件架構(architecture)評估技術包括架構(architecture)權衡分析方法(ATAM)和TARA。[28]比較這些技術的框架在SARA報告[16]和架構評審:實踐和經驗[29]等框架中進行了討論
  • 架構演化是維護和調整現有軟件體系結構以滿足需求和環境變化的過程。由于軟件體系結構提供了軟件系統的基本結構,其演化和維護必然會影響其基本結構。因此,體系結構演進涉及添加新功能以及維護現有功能和系統行為。

架構需要關鍵的支持活動。這些支持活動貫穿于核心軟件架構(architecture)過程。它們包括知識管理和溝通、設計推理和決策以及文檔。

 

架構支持活動

軟件架構(architecture)支持活動在核心軟件架構(architecture)活動期間執行。這些支持活動幫助軟件架構師進行分析、綜合、評估和演化。例如,架構師必須在分析階段收集知識、做出決策和文檔。

  • 知識管理和通信是一種探索和管理知識的行為,對設計軟件體系結構至關重要。軟件架構師不是孤立地工作的。它們從不同的涉眾那里獲得輸入、功能性和非功能性需求以及設計上下文;并向涉眾提供輸出。軟件架構知識通常是默認的,并保留在涉眾的頭腦中。軟件架構知識管理活動是關于發現、交流和保留知識的活動。由于軟件架構設計問題錯綜復雜且相互依存,設計推理中的知識缺口可能導致不正確的軟件架構設計。[23][30]知識管理和溝通活動的示例包括搜索設計模式、原型設計、詢問有經驗的開發人員和架構師,評估類似系統的設計,與其他設計師和利益相關者共享知識,并在wiki頁面中記錄經驗。
  • 設計推理與決策是評價設計決策的活動。這項活動是所有三個核心軟件架構活動的基礎。[9][31]它需要收集和關聯決策上下文,制定設計決策問題,尋找解決方案選項,并在做出決策之前評估權衡。當評估重要的體系結構需求和軟件體系結構決策,以及軟件體系結構分析、合成和評估時,此過程在不同的決策粒度級別上發生。推理活動的例子包括理解需求或設計對質量屬性的影響,質疑設計可能引起的問題,評估可能的解決方案選項,以及評估解決方案之間的權衡。
  • 文檔是記錄軟件架構(architecture)過程中生成的設計的行為。系統設計使用幾個視圖進行描述,這些視圖通常包括顯示系統代碼結構的靜態視圖、顯示系統在執行期間的操作的動態視圖和顯示系統如何放置在硬件上執行的部署視圖。Kruchten的4+1視圖建議描述用于記錄軟件體系結構的常用視圖;[32]記錄軟件體系結構:views and Beyond描述了視圖描述中可以使用的各種符號。[1]文檔活動的示例正在編寫規范,記錄系統設計模型,記錄設計原理,開發觀點,記錄視圖。

軟件架構主題

軟件架構描述

Main article: Software architecture description

軟件架構描述涉及使用架構描述語言、架構視點和架構框架等機制對架構進行建模和表示的原則和實踐。

架構描述語言

Main article: Architecture description language

體系結構描述語言(ADL)是用來描述軟件體系結構(ISO/IEC/IEEE 42010)的任何表達方式。自20世紀90年代以來,開發了許多專用ADL,包括AADL(SAE標準)、Wright(由卡內基梅隆開發)、Acme(由卡內基梅隆開發)、xADL(由UCI開發)、Darwin(由倫敦帝國理工學院開發)、DAOP-ADL(由馬拉加大學開發)、SBC-ADL(由國立中山大學開發)和ByADL(意大利拉奎拉大學)。

架構角度

Main article: View model

「軟件架構」軟件架構概述

 

4+1建筑視圖模型。

軟件架構描述通常被組織成視圖,類似于在建筑架構中生成的不同類型的藍圖。每個視圖都按照其視點的約定處理一組系統關注點,其中視點是一個規范,描述了要在視圖中使用的符號、建模和分析技術,該視圖從給定的一組涉眾及其關注點的角度表示所討論的體系結構(ISO/IEC/IEEE42010)。該視點不僅指定了所構建的關注點(即要解決的關注點),而且還指定了表示、使用的模型類型、使用的約定以及任何保持視圖與其他視圖一致的一致性(對應)規則。

架構框架

Main article: Architecture framework

架構(architecture)框架捕獲“描述在特定應用領域和/或利益相關者社區中建立的架構的慣例、原則和實踐”(ISO/IEC/IEEE42010)。框架通常是根據一個或多個視點或adl來實現的。

架構風格和模式

Main article: Architectural pattern

架構模式是一種通用的、可重用的解決方案,用于解決給定上下文中軟件架構中常見的問題。架構模式通常被記錄為軟件設計模式。

“軟件建筑風格”是繼傳統建筑風格之后的一種特殊的建筑方法,其特點是使其引人注目(建筑風格)

體系結構樣式定義:以結構組織模式表示的一系列系統;組件和連接器的詞匯表,以及如何組合它們的約束條件。[33]

“體系結構樣式是可重用的設計決策和約束的‘包’,應用于體系結構以獲得所選的理想質量。[34]”

有許多公認的建筑模式和風格,其中包括:

  • 黑板
  • 客戶端服務器(2層、3層、n層,云計算展示了這種風格)
  • 基于組件
  • 以數據為中心
  • 事件驅動(或隱式調用)
  • 分層(或多層體系結構)
  • 微服務架構
  • 整體應用
  • 模型視圖控制器(MVC)
  • 對等(P2P)
  • 管道和過濾器
  • 插件
  • 反應式體系結構
  • 代表性狀態轉移(REST)
  • 基于規則
  • 服務導向
  • 無共享架構
  • 天基建筑

有些人認為建筑模式和建筑風格是一樣的,[35]有些人認為風格是模式的專門化。它們的共同點是模式和風格都是建筑師使用的習語,它們“提供了一種共同的語言”[35]或“詞匯”[33]來描述系統的類。

軟件架構與敏捷開發

Main article: Agile development

也有人擔心軟件架構會導致太多的大設計,特別是在敏捷軟件開發的支持者中。已經開發了許多方法來平衡前期設計和敏捷性之間的權衡,[36]包括敏捷方法DSDM,DSDM要求在“基礎”階段打下“足夠”的架構基礎。IEEE軟件專門出版了一期專門討論敏捷性和體系結構之間的交互的專刊[37]。

軟件架構侵蝕

軟件架構侵蝕(或稱“衰退”)是指在軟件系統的實現過程中,在軟件系統的計劃架構和實際架構之間觀察到的差距。[38]當實現決策沒有完全實現計劃架構或違反這種架構。[2]計劃架構和實際架構之間的差距有時可以用技術債務的概念來理解。

例如,考慮一個嚴格分層的系統,其中每個層只能使用它下面的層提供的服務。任何不遵守此約束的源代碼組件都表示違反了體系結構。如果不加以糾正,這種違規行為可能會將體系結構轉換為一個整體塊,從而對可理解性、可維護性和可演化性產生不利影響。

已經提出了各種辦法來解決侵蝕問題。”這些方法,包括工具、技術和過程,主要分為三大類,試圖最小化、防止和修復架構侵蝕。在這些大類中,每一種方法都進一步細分,反映了為解決侵蝕問題而采取的高級別戰略。這些是面向過程的體系結構一致性、體系結構演化管理、體系結構設計實施、體系結構到實現的鏈接、自適應和體系結構恢復技術,包括恢復、發現和協調

檢測體系結構沖突有兩種主要技術:反射模型和領域特定語言。反射模型(RM)技術將系統架構師提供的高級模型與源代碼實現進行比較。還有一些特定于領域的語言,重點是指定和檢查體系結構約束。

軟件架構恢復

Main article: Software architecture recovery

軟件架構(architecture)恢復(或重構,或逆向工程)包括從可用信息(包括其實現和文檔)中揭示軟件系統架構的方法、技術和過程。在面對過時或過時的文檔和架構侵蝕時,架構恢復通常是做出明智決策所必需的:實現和維護決策與設想的架構不同。[40]存在將軟件架構恢復為靜態程序分析的實踐。這是軟件智能實踐課程的一部分。

相關領域

設計

Main article: Software design

架構是設計,但并非所有的設計都是架構。[1]實際上,架構師是在軟件架構(架構設計)和詳細設計(非架構設計)之間劃清界線的人。沒有適合所有情況的規則或準則,盡管有人試圖將這種區別形式化。根據內涵/局部性假設,[41]建筑設計和詳細設計之間的區別是由局部性標準定義的,[41]根據局部性標準,關于軟件設計的陳述是非局部的(建筑),前提是滿足它的程序可以擴展成不滿足它的程序。例如,客戶機-服務器樣式是體系結構(戰略性的),因為基于此原則構建的程序可以擴展為非客戶機-服務器的程序,例如,通過添加對等節點。

需求工程

Main article: Requirements engineering

需求工程和軟件架構可以看作是互補的方法:當軟件架構以“解決方案空間”或“如何”為目標時,需求工程解決“問題空間”或“什么”。[42]需求工程需要啟發、協商、規范、驗證,要求的文件和管理。需求工程和軟件架構都圍繞涉眾的關注點、需求和愿望。

需求工程(engineering)和軟件架構(architecture)之間存在相當大的重疊,例如,對五種工業軟件架構(architecture)方法的研究表明,“輸入(目標、約束等)通常定義不清,只有當體系結構開始出現時才能被發現或更好地理解,并且“雖然大多數體系結構關注點被表達為系統上的需求,但它們也可以包括強制性的設計決策”[24]簡而言之,所需的行為影響解決方案體系結構,這反過來又可能引入新的需求。[43]雙峰模型等方法[44]旨在利用需求和體系結構之間的協同關系。

其他類型的“架構”

Main articles: Computer architecture, Systems architecture, and Enterprise architecture

計算機架構

計算機架構以計算機系統的內部結構為目標,以協作硬件組件(如CPU或處理器、總線和內存)為基礎。

系統架構

術語系統架構最初應用于由硬件和軟件組成的系統架構。系統體系結構解決的主要問題是將軟件和硬件集成到一個完整、正常工作的設備中。在另一個共同的(更廣泛的)含義中,這個術語適用于任何復雜系統的架構,這些系統可能具有技術性、社會技術性或社會性。

企業架構

企業架構的目標是“將業務遠景和戰略轉化為有效的企業”[45]企業架構框架,如TOGAF和Zachman框架,通常區分不同的企業架構層。盡管術語因框架而異,但許多術語至少包括業務層、應用程序(或信息)層和技術層之間的區別。企業架構解決了這些層之間的對齊問題,通常采用自頂向下的方法。

另見

架構模式(計算機科學)

  • 反模式
  • 屬性驅動設計
  • 計算機體系結構
  • 分布式數據管理體系結構
  • 分布式關系數據庫體系結構
  • 系統架構
  • 系統設計
  • 軟件體系結構分析方法
  • 時間觸發系統

本文:
http://jiagoushi.pro/wikipedia-software-architecture

分享到:
標簽:架構 軟件
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定