軟體架構應關心的若幹要素

来源:https://www.cnblogs.com/wangjiming/archive/2019/02/26/10437334.html
-Advertisement-
Play Games

本篇文章主要分析,架構師在設計系統架構時,應關心哪些關鍵要素? 一 業務場景 A公司是一家服裝公司,主要提供服裝一體化服務(服裝設計,服裝銷售,售後服務等),該公司主要通過淘寶,天貓,京東等平臺進行銷售,由於公司 良好的服裝質量,高效的服務水平和良好的信譽等,使得公司的銷售量不斷地增長,到了第五年, ...


      本篇文章主要分析,架構師在設計系統架構時,應關心哪些關鍵要素?

一  業務場景


       A公司是一家服裝公司,主要提供服裝一體化服務(服裝設計,服裝銷售,售後服務等),該公司主要通過淘寶,天貓,京東等平臺進行銷售,由於公司

良好的服裝質量,高效的服務水平和良好的信譽等,使得公司的銷售量不斷地增長,到了第五年,公司的銷售呈現指數型增長....,為了迎合指數型的業務需

求,公司高層決定使用互聯網技術來迎合指數型的業務需求。

        該項目由CTO全程負責,並向CEO彙報,CTO指定小張為該項目業務負責人,小紅為該項目技術負責人,他們兩人定期向CTO彙報。其中,CTO主要負

責系統的系統架構,項目管理,團隊組建,關鍵業務溝通等工作,小張主要負責業務相關的事,如需求調研,需求文檔編寫等,小紅主要負責項目落地開發,

如核心模塊開發,及時解決團隊開發出現的技術性問題。

        如此,CTO做出瞭如下的業務架構,該項目命名為:線上倉儲系統(OnlineWMS)

       (1)通過線上平臺提供的介面,抓取用戶訂單

       (2)將抓取的訂單存儲到倉儲系統

       (3)將訂單相關信息傳遞給SAP(可以理解為財務系統)

       (4)當貨物發送後,在WMS系統上,通過物流介面查詢訂單狀態(發送,未發送,已收貨,退貨等)

 

二   架構師應關心的若幹要素


 1.明確系統功能(what)

在業務架構中,系統架構師一定要非常瞭解且明確系統要解決的核心業務,在設計前,建議考慮如下問題:

項目需求是什麼?

項目需求是基於什麼背景下提出的?

項目需求的核心業務是什麼?

項目需求的難點和痛點是什麼?

....

在充分考慮如上問題後,就是問題答案的尋找和求證過程:

答案尋找?

如上系列問題,均可在需求文檔中找到,因為一般情況,需求文檔都會有詳細描述,需求文檔的來源一般經過幾個階段:

需求提出=》需求調研=》需求初稿=》需求評審=》需求修改=》需求定稿

答案求證?

系統架構師在充分研讀需求文檔後,對需求基本有所瞭解,然而這些所謂的瞭解,是需要與需求提出者,需求撰寫者等關鍵人物確認的

確認的,這個過程也叫答案的求證過程,只有該過程確定後,方可進行下一環節。

2.定義系統邊界(Scope)

在充分明確需求後,就要定義系統邊界了,首先來瞭解一下,什麼叫系統邊界。

系統邊界:指本次項目由哪些系統構成(或子系統構成)。

CTO為OnlineWMS系統定義了四個邊界:線上介面(訂單的來源),物流介面(訂單狀態查詢),WMS系統(訂單管理,衣物存儲等),SAP系統

(財務相關)

 很容易看出,這幾個邊界定義還是比較明顯的,職責分工明確,無重疊業務。

 

3.定義系統之間的交互方式

CTO為OnlineWMS系統定義了四個邊界,且這四個邊界的交互方式是以介面的方式進行的。

4.介面設計規範

關於介面設計規範,請參考我的另一篇文章  如何設計一個良好的介面

5.系統難點

該系統,從線上抓單,且將訂單及時地存儲到WMS系統是一大難點和挑戰點,尤其在雙十一,雙十二等高峰時段,成千上萬的高併發量,

10w-1000w的訂單量等都完全有可能導致系統崩潰。然而,該難點卻有很多可以捕捉的特點,歸結如下:

(1)存在高併發量特征

(2)存在大規模訂單特征

(3)存在系統響應及時特征

(4)存在高併發、大規模訂單集中於某個時間段,而非長時間(如1年)特征

.......

6.業務模塊與非業務模塊拆分

該系統中,存在業務模塊與非業務模塊,需要進行拆分,如非業務模塊授權管理、日誌記錄等需要從業務中拆分開發來,可以採用AOP技術

實現,如Spring AOP,AspectJ等。

7.模塊解耦

該系統中,模塊之間存在必要的依賴關係,為了儘可能的降低這些依賴關係,可以採用DI(依賴註入技術)來解決,如Spring框的DI。

8.技術選型

涉及到前端框架,後端框架,ORM框架等。

在選擇框架時,儘量選擇主流且被廣泛使用的框架,儘量不要選擇不太主流或太新的框架。

在框架組合時,防止過大,也防止過小,如SSH,SSM,SpringBoot+SpringCloud+Redis+Mongo+MQ+Dubbo等,要根據具體的業務場景來選擇。

9.開發團隊

在組建團隊時,要充分考慮風險,如團隊人員突然離職造成項目延誤等風險,建議採用職能組織架構結構來組建團隊。如一個技術開發經理,2個高級開發,3個中級,4個初級等,

這樣搭配的好處是,當技術開發經理突然離職(一般技術開發經理很少離職),2個高級開發可以頂替上去;若有一個高級開發離職,兩個中級可以頂替上去....如此,就算某個人離職,

對項目影響都不會太大。

10.項目管控

管理項目計劃,項目進度,開發團隊人員情緒、處理開發技術問題等。

三  版權區


  •    轉載博客,必須註明博客出處
  •    博主網址:http://www.cnblogs.com/wangjiming/
  •    如您有新想法,歡迎提出,郵箱:[email protected]

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

-Advertisement-
Play Games
更多相關文章
  • Echarts堆積柱狀圖排序是按照堆積柱狀圖的柱子高度進行從大到小(或者從小到大)進行排序,方便查閱各坐標情況。以下是我自己研發的方法,有不對的地方敬請諒解,隨時歡迎指教。 排序後效果如下圖: (1)排序函數,這是一個簡單的冒泡排序,首先計算橫坐標各柱子的和,然後進行簡單的冒泡排序(因為時間緊),可 ...
  • vux VUX 是基於 WeUI 和 Vue.js 的 移動端 UI 組件庫,提供豐富的組件滿足移動端(微信)頁面常用業務需求。 在vue cli中使用步驟如下: 1、安裝: npm i vux S 2、vux2必須配合vux loader使用,並配置build/webpack.base.conf. ...
  • 實現思路: 1、 v model 一個收集所有input(除全選框外)數組checkModel ,vue會動態將其checked為true的input的value值存入數組checkModel里 2 、watch函數來監聽checkModel 屬性,當其長度==input元素時 全選按鈕選中 否則取 ...
  • 1. 在 router目錄下 的 index.js文件中,新增路由 import City from '@/pages/city/City' { path: '/city', name: 'City', component: City } 2. 在city 目錄下新建city文件夾,然後新建 Cit ...
  • ├── README.md 項目介紹├── index.html 入口頁面├── build 構建腳本目錄│ ├── webpack.base.conf.js webpack基礎配置,開發環境,生產環境都依賴 │ ├── webpack.dev.conf.js webpack開發環境配置│ ├── ...
  • 前面介紹了Util是如何封裝以降低Angular應用的開發成本。 現在把關註點移到服務端,本文將介紹分層架構各構造塊及基類,並對不同層次的開發人員應如何進行業務開發提供一些建議。 Util分層架構介紹 為了控制業務邏輯複雜性,Util引入了DDD分層架構,這意味著如果你想使用DDD,Util會為你提 ...
  • 需求緣起(用一個公司的發展作為背景) 1.還是個小公司的時候,註冊用戶就20w,每天活躍用戶1w,每天最大單表數據量就1000,然後高峰期每秒併發請求最多就10,此時一個16核32G的伺服器,每秒請求支撐在2000左右,負載合理,沒有太大壓力,基本沒有宕機風險。 2.當註冊用戶達到2000W,每天活 ...
  • 一.Django的視圖函數view 一個視圖函數(類),簡稱視圖,是一個簡單的Python函數(類),它接受WEB請求並返回Web響應. 響應可以是一張網頁的HTML內容,一個重定向,一個404錯誤,一個XML文檔,或者一張圖片. 無論視圖本身包含什麼邏輯,都要返迴響應.代碼寫在哪裡也無所謂,只要它 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...