架構雜談《二》

来源:https://www.cnblogs.com/haoxiaozhang/archive/2019/07/11/11172670.html
-Advertisement-
Play Games

架構雜談《二》 服務化到微服務 1、微服務的產生 隨著互聯網企業的不斷發展,海量用戶發起的大規模、高併發請求是企業不得不面對的,上一篇 架構雜談《一》雜談的SOA服務化系統能夠分解任務,讓每個服務更簡單、職責單一、更易於擴展。但無論是Web Service 還是ESB,都有時代遺留下的問題。 Web ...


架構雜談《二》

 

服務化到微服務

1、微服務的產生

  隨著互聯網企業的不斷發展,海量用戶發起的大規模、高併發請求是企業不得不面對的,上一篇 架構雜談《一》雜談的SOA服務化系統能夠分解任務,讓每個服務更簡單、職責單一、更易於擴展。但無論是Web Service 還是ESB,都有時代遺留下的問題。

  Web Service

   1)依賴中心化的服務發現機制

   2)使用SOAP通訊協議,通常使用XML格式來序列化通信數據,XML格式的數據冗餘太大,協議太重

   3)服務化管理和治理設施並不完善

  ESB

   1)ESB 雖然是SOA實現的一種方式,卻更多地體現了系統集成的便利性,通過統一的服務匯流排將各個服務組合在一起

        2)組合在ESB上的服務本身有可能是一個臃腫的服務

   3)系統內部的複雜性仍然存在。ESB試圖通過匯流排來掩蓋系統內部的複雜性

        4)對於匯流排本身中心化的管道模型,系統變更時影響的範圍會隨之擴大

出現問題解決問題是人類進步的階梯,對於軟體架構也是一樣,近年來服務架構設計得到了進一步的演化和發展,微服務架構已經出現在不同公司的討論、設計和實踐中,經過市場檢驗的東西肯定會被大家所接受。

  微服務架構提倡將軟體應用設計成多個可獨立開發、配置、運行和維護的子服務,子服務之間通過良好的介面定義通信機制,通常使用RESTful風格的API形式來通信。因為RESTful 風格的 API 通常是在 HTTP 或者 HTTPS 通道上傳輸 JSON 格式的數據來實現的, HTTP協議有跨語言、跨異構系統的優點, 當然也可通過底層的二進位協議、消息隊列協議等進行交互。這些服務不需要中心化的統一管理,每個服務的功能可自治,並且可由不同的語言、系統和平臺實現 。 

  微服務架構致力於松耦合和高內聚的效果,與SOA和ESB相比,不再強調服務匯流排和通信機制的多樣性,通常通過RESTful 風格的API和輕量級的消息通信協議來完成。

微服務架構並不是為了拆分而拆分,真正的目的是通過對微服務進行水平擴展解決傳統的單體應用在業務急劇增長時遇到的問題,而且由於拆分的微服務系統中專業的人做 專業的事,人員和項目的職責單一、低藕合、高內聚,所以產生問題的概率就會降到最小。

2、微服務與單體的對比

 

(微服務架構圖)

從上圖可以得到:

  1)  微服務把每一個職責單一的功能放在一個獨立的服務中

  2)  每個服務運行在一個單獨的進程中

  3)  每個服務有多個實例在運行,每個實例可以運行在容器化平臺內

  4)  每個服務有自己的數據存儲,實際上,每個服務應該有自己獨享的資料庫、緩存、消息隊列等

  5)  每個服務都可根據性能需求獨立地水平伸縮

 

(單體架構圖)

通過對比,可以得到傳統單體架構的特點:

  1)  傳統單體架構將所有模塊化組件糅合後運行在同一個服務的進程中

  2)  某個模塊發生變更時,需要將所有的模塊編譯、打包上線

  3)  久而久之,模塊間的依賴將會不清晰,互相耦合,互相依賴成為常態

通過將兩種架構對比來看,微服務架構更加的靈活並且可水平伸縮,可以讓專業的人乾專業的事。

3、微服務與SOA服務的對比

  微服務架構的一些特點與 SOA 服務化架構相似, 事實上微服務架構與 SOA 服務化架構並不衝突,它們一脈相承,微服務架構是服務化架構響應特定歷史時期的使用場景的延續,是服務化進行升華井落地的一種實現方式。 SOA 服務化的理念在微服務架構中仍然有效,微服務在 SOA 服務化的基礎上進行了演進和疊加,形成了適合現代化應用場景的一個方法論。

經過幾十年互聯網的高速發展,以及敏捷、持續集成、持續交付、DevOps、雲技術等的深入人心,服務架構的開發、測試、部署以及監控等,相比SOA已經發生大的變化。

  1)  SOA 服務化涉及的範圍更廣一些,強調不同的異構服務之間的協作和契約 ,並強調有效集成、業務流程編排、歷史應用集成等,典型代表為 Web Service 和 ESB

  2)  微服務使用一系列的微小服務來實現整體的業務流程,目的是有效地拆分應用,實現敏捷開發和部署,在每個微小服務的團隊里,減少了跨團隊的溝通,讓專業的人做專業的事,縮小變更和法代影響的範圍,並達到單一微服務更容易水平擴展的目的

  3)  微服務將完整的應用拆分成多個細小的服務,通常使用敏捷擴容、縮容的 Docker 技術來實現自動化的容器管理 , 每個微服務運行在單一的進程內,微服務中的部署互相獨立 、 互不影響。

  4)  SOA 服務化通常將多個業務服務通過組件化模塊方式打在一個包里,然後統一部署在一個應用伺服器上。

  6)  SOA 對粒度沒有要求 , 在實踐中服務通常是粗粒度的,強調介面契約的規範化,內部實現可以更粗粒度。

相比SOA的服務實現方式,微服務更具靈活性、可實施性以及可擴展性,其強調的是一種獨立測試、獨立部署、獨立運行的軟體架構模式。對於微服務的概念而言,它是SOA的一個子集,而對於其實現方式而言,它是一種更符合現代化互聯網發展趨勢的實踐,是一種更容易幫助企業或組織有效併成功實施的服務架構。

總結

最後讓我來總結下微服務架構的主要特點

  • 將傳統單體應用拆分成網路服務,來實現模塊化組件 。
  • 根據微服務架構的服務劃分來分組職能團隊,減少跨團隊的溝通 。
  • 每個服務對應一個團隊,團隊成員負責開發、測試、運維和運營 ,開發後在團隊內運維和運營,不需要交付給其他團隊。
  • 去中 心化、 去 SOA 服務化的中 心服務治理和去企業服務匯流排 。
  • 微服務重視服務的合理拆分、分層和構造,可建設自動化持續發佈平臺,井進行敏捷開發和部署。

 說明:

  1、文中的圖都來自於百度圖片

  2、參考書籍:《分散式服務架構:原理、設計與實戰》

  3、如有不合適的地方請反饋。綜合後更改。

 


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

-Advertisement-
Play Games
更多相關文章
  • 以上是效果圖,本圖表使用d3.js v4製作。圖表主要功能是在六邊形格子中顯示數據,點擊底部圖標可以切換指定格子高亮顯示,圖表可以隨瀏覽器任意縮放。 1.圖表的主體結構是由正六邊形組成,使用d3生成六邊形可以使用d3-hexbin.js,生成六邊形比較方便,只要給定中心點坐標和半徑即可生成六邊形路徑 ...
  • 問題一、微信瀏覽器中無法使用reload重載文檔【VUE框架】 問題分析: 微信不支持location.reload()方法,在微信瀏覽器中會失效 Vue中的路由跳轉是類似於ajax局部刷新,因此使用location.href=‘xxx+時間戳’ 這種方法時,頁面不會重載 Vue自帶的this.$r ...
  • 1.地圖繪製過程原理 給定範圍邊界經緯度數據,再給它個名字就構成了繪製地圖的基礎。也就是說,你可以繪製任意形狀的地圖版塊。 2.地圖數據生成 中國以及省市縣等地圖的基礎數據可以從這裡生成與下載。 "http://datav.aliyun.com/tools/atlas" 有了地圖範圍數據,在 ech ...
  • 哈哈,久違了各位。我又回來了,最近在做畢設,所以難免會遇到很多問題,需要解決很多問題,在萬能的博友幫助下,終於解決了Element-ui中輪播圖的圖片高度問題,話不多說上代碼。 那個axios的使用不重要,大致思路就是頁面渲染前拿到當前視窗的寬度*圖片比例給輪播圖一個初始的高度,當窗後大小發生變化時 ...
  • 本人剛學先上鏈接(別人寫的挺好的)後期同步補上😄!!! 網站鏈接:https://blog.csdn.net/baozhiqiangjava/article/details/81178694 GitHub:https://github.com/JsAaron/jQuery ...
  • SpringCloud系列教程 | 第十二篇:Spring Cloud Gateway初探 Springboot: 2.1.6.RELEASE SpringCloud: Greenwich.SR1 如無特殊說明,本系列教程全採用以上版本 前面我們在聊服務網關Zuul的時候提到了Gateway,那麼Z ...
  • "JavaScript 設計模式基礎(一)" "小菜鳥的個人博客" 原型模式 在以類為中心的面向對象編程語言中,類和對象的關係就像鑄模和鑄件的關係,對象總是從類中創建。而原型編程中,類不是必須的,對象未必從類中創建而來,可以拷貝另一個對象而變成新對象 從設計模式角度講,原型模式是用於創建對象的一種模 ...
  • 相比較傳統的工廠模式IFactory/Concrete Factory會反覆引用並編譯代碼 但是作為開發人員,我們更希望的是少修改代碼,儘量從配置著手也就是設計模式的根本原則之一:開放封閉原則。如果我要增加新的產品,那麼修改就比較大了,對於業務來講還是可以接受的。但是如果可以做到不修改代碼是最好的。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...