這個架構能實現嗎?

来源:http://www.cnblogs.com/mindwind/archive/2017/05/31/6922375.html
-Advertisement-
Play Games

近來一直在做一個產品的架構升級,架構升級的前期工作是對舊架構現存的問題進行梳理,考慮新架構的設計如何規避舊架構的坑,完善舊架構支持不佳的缺陷。終於完成了新架構設計,在給開發工程師講解時,還會遇到開發的疑惑:新架構真能實現舊架構上支持的特別困難或彆扭的場景麽,如此等等。一個架構從設計到實現,到底要做些 ...


近來一直在做一個產品的架構升級,架構升級的前期工作是對舊架構現存的問題進行梳理,考慮新架構的設計如何規避舊架構的坑,完善舊架構支持不佳的缺陷。終於完成了新架構設計,在給開發工程師講解時,還會遇到開發的疑惑:新架構真能實現舊架構上支持的特別困難或彆扭的場景麽,如此等等。一個架構從設計到實現,到底要做些什麼,關註些什麼?

那麼我們就從下麵這個問題開始梳理吧。

架構做什麼

查了下維基百科(Wikipedia)架構(Architecture)一詞最早源自建築學術語,後來被電腦科學領域所借用。

架構是規劃、設計和構建建築及其物理結構的過程與產物。在電腦工程中,架構是描述功能、組織和電腦系統實現的一組規則與方法。
Architecture is both the process and the product of planning, designing, and constructing buildings and other physical structures. In computer engineering, "computer architecture" is a set of rules and methods that describe the functionality, organization, and implementation of computer systems.

要明白做什麼,首先需要考慮目標是什麼?軟體架構的目標是要設計軟體系統來解決問題,所以架構要做的事從抽象的維度上看,就是:

  • 根據問題域,界定系統的邊界
  • 對系統進行切分,切分的目的是分工與協作(並行,以獲得效率)
  • 被切分的各部分之間建立交互與溝通原則與機制
  • 將部分連接合併成一個整體,完成系統的目標

更具體一些來說,架構做得就是結構設計,在不同維度和層次上:

  • 高維度:是系統、子系統或服務的切分與交互結構
  • 中維度:是系統或服務內部的模塊劃分
  • 低緯度:是代碼結構、數據結構、表結構

當在架構升級這樣的事情中,架構師的職責之一是要交付“一種架構”,而這“一種架構”的載體現在通常又會以某種文檔的形式出現。所以,很容易誤解架構師的工作就是寫文檔,實際上架構師的交付成果是一整套決策流,交付載體通常體現成了文檔。在這個過程中,架構師的首要工作就是保證在架構方案執行中,整個開發團隊的實施效果與決策保持一致。即使在這個過程發現了實施與決策的衝突,就又需要重新協調溝通討論以取得新的一致。

當系統規模比較小時,比如架構師一個人就能把全部的設計決策在交付期限內開發完成,這就省卻了很多的溝通協調討論成本。五年前,我就曾這樣做過一個小系統的架構升級改造,但後來的系統越來越大,慢慢就需要幾十人的團隊來分工協作,如何保證架構設計中的決策在架構執行過程中保持一致,這成為了架構工作的真正難點所在。

架構關註點

架構設計的決策流一旦落在了文檔的載體上,它實際就是一個靜態的東西了。而真正的架構執行過程卻是動態的。在這個動態過程中,架構師需要定期地去對系統的狀態做快照,觀察是否有出現需要解決的問題,而這些問題就是技術層面的架構關註點。

一些問題也許是架構執行中新出現的,在當初的架構設計中未能考慮到,需要對此做分析判斷,並形成新的決策。而另一些問題,也許是執行過程中的走樣,導致和當初的決策形成了偏差。架構師需要考慮所有這些關註點,並和開發工程師找到解決這些關註點的各種選項,在適當的時候根據真實環境的情景去採取合適的行動。有時,我們稱這些行動叫作:重構或優化。當一個舊系統長期沒有這樣的行動,積累久了後,我們將迫不得已採取另外一種行動,我們稱之為 —— 架構升級。

軟體系統或架構,不像建築物會因為時間的流逝而自然耗損腐壞,它只會因為變化而腐壞。一開始清晰整潔的架構與實現隨著需求的變化而不斷變得渾濁、混亂。信息與電腦科學都愛借用一個物理學的術語「熵」,它表達體系的混亂程度,而軟體系統的「熵」很容易不經意間隨著需求的變化而變得更高。

軟體系統「熵」有個臨界值,當達到並超過臨界值後,軟體系統的生命也基本到頭了。這時,我們就要採取那個迫不得已的行動了。圖例展示了軟體系統「熵」值的生命周期變化。

所以,近年流行的微服務架構有個很大的優勢,服務粒度合適,服務物理隔離,單個服務的「熵」增問題被局限在單個微服務內部。單個微服務的替換與重構成本十分有限,使得「熵」增問題局部化,不容易傳染全局,以致失控。當然這有個前提,就是微服務的拆分和介面交互要合理,合理的檢驗標準就是隨需求變化,總是實現變化或介面新增,而非總是調整介面交互。

架構始於系統生命之初,並伴隨系統生命周期全程。每次需求變化帶來的變動都應進行一次或大或小的重新架構過程。架構的關註點在於控制軟體系統變動時「熵」值的變化。

架構等效性

架構升級中一開始的疑惑:這個新架構能實現麽?其實,這根本不是一個值得疑惑的問題。

相對於建築架構,軟體架構過程其實更像是城市的規劃與演變過程,有一定歷史的城市,慢慢都會演變出所謂的“舊城”和“新城”,新城相對於舊城,就是一次架構升級的過程。城市規劃師會對城市的分區、功能劃分進行重新定位和規劃。一個舊城所擁有的所有功能,如:社區、學校、醫院、商業中心,你難道能想象新城會沒有嗎?或者說“實現”不了嗎?

所以,如果一個單體應用能實現的功能,換成微服務架構肯定也可以實現,只是編寫代碼的方式不同。不同架構在功能的可實現性上其實是完全相同的,我稱之為:架構等效性。不同的地方在於哪裡呢?如前所述,切分方式不同導致的分工協作完全不同,因此獲得的效率與付出的成本也會不同。

架構升級,僅僅是一次系統的重新佈局與規劃,成本與效率的重新計算與設計,熵的重新分佈與管理。

...

架構就是關於系統的決策流。
架構關註系統「熵」的變化。
架構都是等效的,不同的是成本和效率。

新城區(架構)活動的人(需求)多了,也是要堵車(...)的。


寫點文字,畫點畫兒,記錄成長瞬間。
微信公眾號「瞬息之間」,既然遇見,不如一起成長。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一 概述 1.什麼是觀察者模式? 將一個對象視作被觀察者,當它發出某種行為或者發生某種變化時,通知所有依賴它的對象(觀察者),這種設計模式叫做觀察者設計模式。 2.觀察者設計模式的用途 用於處理一對多的依賴關係,當一個對象的狀態發生改變時,通知所有依賴於它的對象,這些對象收到通知以後採取相應的處理措 ...
  • 一 概述 1.什麼是裝飾者模式? 在不修改類,不使用繼承的前提下,用一個對象來裝飾另一個對象,以擴展目標對象的功能。 2.裝飾者模式的作用: 繼承也可以擴展類的功能,裝飾者模式比繼承更加靈活,因為繼承時子類受父類的約束,比如子類方法不能降低訪問許可權,返回值必須是父類方法返回值的子類,而裝飾模式就不受 ...
  • 分享生產列印系統的項目管理、研發、測試、運維等各方面的經驗。嘗試介紹我們設計新折桂列印平臺系統的思路。拋磚引玉,期望與大家交流。 ================================ ...
  • Git是分散式的代碼管理工具,遠程的代碼管理是基於SSH的,所以要使用遠程的Git則需要SSH的配置。 github的SSH配置如下: 一 、 設置Git的user name和email: 二、生成SSH密鑰過程:1.查看是否已經有了ssh密鑰:cd ~/.ssh如果沒有密鑰則不會有此文件夾,有則備 ...
  • 《O’Reilly:Head First設計模式(中文版)》趨近完美,因為它在提供專業知識的同時,仍然具有相當高的可讀性。 本書共有14章,每章都介紹了幾個設計模式,完整地涵蓋了四人組版本全部23個設計模式。 ★前言介紹了這本書的用法 ★第1章至第11章陸續介紹了設計模式:Strategy、Obse ...
  • 1.什麼是介面? 介面是事物最高的概括,從最高層次上設計了事物的形態。本質上是一系列規範,所有實現了介面的類都實現了該規範,從而使得在相容該規範的地方任何一個實現類都適用。 2.什麼是面向介面編程? 需求商品時,不是指定特定的商品,而是指定需求的條件,任何一個符合條件的事物都可以成為合格的商品。具體 ...
  • 最近一直在重溫設計模式的知識,或者實際項目中運用的並不多,但設計思想才是最重要的。本系列博文均是自己總結記錄之用,僅僅代表個人觀點。若是能幫到正在IT路上前行的同行,那是最好不過了。 關於設計模式,百度百科上的定義是 設計模式(Design Pattern)是一套被反覆使用、多數人知曉的、經過分類的 ...
  • 上篇說到設計模式的精髓是原則和思想,這篇文章就詳細介紹一下設計模式的原則。 一、單一職責原則 定義:就一個類而言,應該僅有一個引起它變化的原因。 人都說,這個原則太普通了,和名字一樣簡單。不是說大道至簡嘛,這個原則在程式設計中所占的份量還是很重的。 一個類涉及的多項功能,如果其中一個功能發生改變需要 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...