SCS(- )架構介紹

来源:https://www.cnblogs.com/wintersun/p/18368156
-Advertisement-
Play Games

SCS(- )架構介紹SCS(- )架構定義與特性自主Web應用:SCS是一個自主的Web應用程式,包含Web UI、邏輯和持久化層。這種完整性確保了一個用戶故事通常可以通過修改一個SCS來實現。 API的可選性:SCS可以有一個服務API,但這並非必需。如果SCS內的邏輯僅由SCS內的UI使用,則 ...


SCS(- )架構介紹


SCS(- )架構定義與特性

image

  • 自主Web應用:SCS是一個自主的Web應用程式,包含Web UI、邏輯和持久化層。這種完整性確保了一個用戶故事通常可以通過修改一個SCS來實現。
  • API的可選性:SCS可以有一個服務API,但這並非必需。如果SCS內的邏輯僅由SCS內的UI使用,則無需API。
  • 無共用UI:SCS之間不應共用UI,以避免緊密耦合和不必要的複雜性。



image

  1. SCS與微服務的關係
    • 類似但更精確:SCS與微服務在可獨立部署和解耦方面相似,但SCS的定義更為精確,通常粒度更粗。
    • 單個功能實現:SCS確保一個功能僅在一個SCS中實現,從而通過單一部署即可將其投入生產。
  2. Bounded Context與DDD
    • Bounded Context:每個SCS應實現一個Bounded Context,通過用戶故事分組來找到這些Bounded Context。
    • 用戶故事與旅程:通過用戶故事和用戶旅程來確定SCS的劃分,每個步驟或需求可能是一個SCS的候選。
  3. SCS的溝通與交互
    • UI集成:UI集成是首選的SCS間溝通方式,包括JavaScript轉碼、ESI和SSI等技術。
    • 非同步與同步通信:非同步通信(如事件和消息傳遞)是推薦的溝通方式,同步通信則作為最後手段。
  4. 團隊與所有權
    • 單一團隊擁有:每個SCS由單一團隊擁有,確保團隊可以獨立工作,並減少協調需求。
  5. 技術優勢與限制
    • 技術優勢:SCS提供了高開發生產力和低技術複雜性,因為它們通常是傳統的Web應用程式。
    • 限制:SCS主要適用於Web系統,且可能需要對前端開發有一定的技能要求。
  6. 實際應用與案例
    • Otto案例:Otto等大型電商公司採用SCS架構,證明瞭其在複雜Web應用中的有效性。
  7. 遷移與實現難度
    • 遷移挑戰:如果現有架構依賴於不同的方法,遷移到SCS架構可能具有挑戰性。
    • 實施要求:對Web應用程式的深入理解是實現SCS架構的重要前提。



單體

image

微服務

image

SCS

image



為什麼自包含系統 (SCS) 比微服務更具優勢:

image

更廣泛的範圍:SCS 具有更廣泛的範圍,包括邊界上下文中的 UI、業務邏輯和數據存儲

  降低運營複雜性:由於管理許多較小的、相互依賴的服務,微服務可能會導致高水平的運營複雜性,而 SCS 更重要、更自主。

  數據一致性:SCS 管理其數據,從而在每個系統內實現更好的數據一致性,而微服務通常依賴於共用數據存儲。


使用SCS架構優勢

image

1. 自治 - 每個 SCS 都獨立運行,具有其資料庫、業務邏輯和用戶界面。

2. 領域對齊 - SCS 圍繞特定的業務領域構建,確保每個單元代表一組連貫且有意義的功能。

3. 去中心化數據管理 - 每個 SCS 的單個資料庫確保其邊界內的數據一致性,減少跨服務依賴性。

4. 技術多樣性 - 允許在其他 SCS 中使用不同的技術堆棧,以滿足每個領域的特定需求。

5. 顯式發佈的介面 - 定義明確的介面,用於與其他系統的交互,在保持封裝的同時保持清晰的契約。

6. 獨立可部署性 - 每個 SCS 都可以獨立部署、擴展和更新,而不會影響其他系統。


結論

      SCS是一種微服務架構的實踐方法,它通過將系統劃分為自主的Web應用程式(SCS),實現了高度的解耦和獨立部署。SCS強調每個SCS實現一個Bounded Context,並通過UI集成和非同步通信等方式保持低耦合。SCS適用於複雜的Web系統,並提供了高開發生產力和低技術複雜性的優勢。然而,其實現需要對Web應用程式有深入的理解,並且遷移到SCS架構可能具有挑戰性。



今天先到這兒,希望對AIGC,雲原生,技術領導力, 企業管理,系統架構設計與評估,團隊管理, 項目管理, 產品管理,信息安全,團隊建設 有參考作用 , 您可能感興趣的文章:
構建創業公司突擊小團隊
國際化環境下系統架構演化
微服務架構設計
視頻直播平臺的系統架構演化
微服務與Docker介紹
Docker與CI持續集成/CD
互聯網電商購物車架構演變案例
互聯網業務場景下消息隊列架構
互聯網高效研發團隊管理演進之一
消息系統架構設計演進
互聯網電商搜索架構演化之一
企業信息化與軟體工程的迷思
企業項目化管理介紹
軟體項目成功之要素
人際溝通風格介紹一
精益IT組織與分享式領導
學習型組織與企業
企業創新文化與等級觀念
組織目標與個人目標
初創公司人才招聘與管理
人才公司環境與企業文化
企業文化、團隊文化與知識共用
高效能的團隊建設
項目管理溝通計劃
構建高效的研發與自動化運維
某大型電商雲平臺實踐
互聯網資料庫架構設計思路
IT基礎架構規劃方案一(網路系統規劃)
餐飲行業解決方案之客戶分析流程
餐飲行業解決方案之採購戰略制定與實施流程
餐飲行業解決方案之業務設計流程
供應鏈需求調研CheckList
企業應用之性能實時度量系統演變

如有想瞭解更多軟體設計與架構, 系統IT,企業信息化, 團隊管理 資訊,請關註我的微信訂閱號:

image_thumb2_thumb_thumb_thumb_thumb[2]

作者:Petter Liu
出處:http://www.cnblogs.com/wintersun/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。 該文章也同時發佈在我的獨立博客中-Petter Liu Blog。


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

-Advertisement-
Play Games
更多相關文章
  • 一、載入問題 用高德地圖做了個進京證路線規劃的功能,官網也是有 React 代碼示例。但是吧,這個Demo有問題,地圖是能載入成功,但是其他功能再用 map 這個變數肯定不行,果不其然是null,處理也簡單,把公共變數都管理起來就行了。 const [map, setMap] = useState( ...
  • title: 使用 onBeforeRouteUpdate 組合式函數提升應用的用戶體驗 date: 2024/8/15 updated: 2024/8/15 author: cmdragon excerpt: 摘要:本文介紹如何在Nuxt 3開發中使用onBeforeRouteUpdate組合式函 ...
  • 歐陽堅持每周更新一篇高質量文章半年後的收益:收入1380.27元、電子書一本、微信技術群418人、微信好友459人、文章38篇 ...
  • 本文比較了NPM、Yarn 和 pnpm 三種包管理工具的特點,重點分析了它們在安裝速度、依賴管理、磁碟空間使用、依賴衝突處理等方面的差異,重點介紹了pnpm的依賴組織結構。 ...
  • 前言 在現代 Web 開發中,WebAssembly (WASM) 已成為一種強大的工具。它使得開發者可以在瀏覽器中運行高性能的代碼,跨越傳統的 JavaScript 性能限制。Rust 語言因其高效性和記憶體安全性,成為了編寫 WASM 模塊的熱門選擇。本文將介紹如何將 Rust 代碼編譯為 Web ...
  • title: 使用 onBeforeRouteLeave 組合式函數提升應用的用戶體驗 date: 2024/8/14 updated: 2024/8/14 author: cmdragon excerpt: 摘要:本文介紹了在Nuxtjs中使用onBeforeRouteLeave組合式函數來提升應 ...
  • 什麼是Web Component Web Component是一套Web瀏覽器的技術和規範,能夠讓開發者定製自己的HTML元素 來自MDN的描述: Web Component 是一套不同的技術,允許你創建可重用的定製元素(它們的功能封裝在你的代碼之外)並且在你的 web 應用中使用它們。 Web C ...
  • title: 使用 navigateTo 實現靈活的路由導航 date: 2024/8/13 updated: 2024/8/13 author: cmdragon excerpt: 摘要:本文詳細介紹 Nuxt.js 中的 navigateTo 函數,包括基本用法、在路由中間件中使用、導航到外部 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 推薦一款基於.NET 8、WPF、Prism.DryIoc、MVVM設計模式、Blazor以及MySQL資料庫構建的企業級工作流系統的WPF客戶端框架-AIStudio.Wpf.AClient 6.0。 項目介紹 框架採用了 Prism 框架來實現 MVVM 模式,不僅簡化了 MVVM 的典型 ...
  • 先看一下效果吧: 我們直接通過改造一下原版的TreeView來實現上面這個效果 我們先創建一個普通的TreeView 代碼很簡單: <TreeView> <TreeViewItem Header="人事部"/> <TreeViewItem Header="技術部"> <TreeViewItem He ...
  • 1. 生成式 AI 簡介 https://imp.i384100.net/LXYmq3 2. Python 語言 https://imp.i384100.net/5gmXXo 3. 統計和 R https://youtu.be/ANMuuq502rE?si=hw9GT6JVzMhRvBbF 4. 數 ...
  • 本文為大家介紹下.NET解壓/壓縮zip文件。雖然解壓縮不是啥核心技術,但壓縮性能以及進度處理還是需要關註下,針對使用較多的zip開源組件驗證,給大家提供個技術選型參考 之前在《.NET WebSocket高併發通信阻塞問題 - 唐宋元明清2188 - 博客園 (cnblogs.com)》講過,團隊 ...
  • 之前寫過兩篇關於Roslyn源生成器生成源代碼的用例,今天使用Roslyn的代碼修複器CodeFixProvider實現一個cs文件頭部註釋的功能, 代碼修複器會同時涉及到CodeFixProvider和DiagnosticAnalyzer, 實現FileHeaderAnalyzer 首先我們知道修 ...
  • 在軟體行業,經常會聽到一句話“文不如表,表不如圖”說明瞭圖形在軟體應用中的重要性。同樣在WPF開發中,為了程式美觀或者業務需要,經常會用到各種個樣的圖形。今天以一些簡單的小例子,簡述WPF開發中幾何圖形(Geometry)相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 在 C# 中使用 RabbitMQ 通過簡訊發送重置後的密碼到用戶的手機號上,你可以按照以下步驟進行 1.安裝 RabbitMQ 客戶端庫 首先,確保你已經安裝了 RabbitMQ 客戶端庫。你可以通過 NuGet 包管理器來安裝: dotnet add package RabbitMQ.Clien ...
  • 1.下載 Protocol Buffers 編譯器(protoc) 前往 Protocol Buffers GitHub Releases 頁面。在 "Assets" 下找到適合您系統的壓縮文件,通常為 protoc-{version}-win32.zip 或 protoc-{version}-wi ...
  • 簡介 在現代微服務架構中,服務發現(Service Discovery)是一項關鍵功能。它允許微服務動態地找到彼此,而無需依賴硬編碼的地址。以前如果你搜 .NET Service Discovery,大概率會搜到一大堆 Eureka,Consul 等的文章。現在微軟為我們帶來了一個官方的包:Micr ...
  • ZY樹洞 前言 ZY樹洞是一個基於.NET Core開發的簡單的評論系統,主要用於大家分享自己心中的感悟、經驗、心得、想法等。 好了,不賣關子了,這個項目其實是上班無聊的時候寫的,為什麼要寫這個項目呢?因為我單純的想吐槽一下工作中的不滿而已。 項目介紹 項目很簡單,主要功能就是提供一個簡單的評論系統 ...