微服務,為什麼可以加速分工、促進合作?

来源:https://www.cnblogs.com/itlaobingge/archive/2020/01/15/12195492.html
-Advertisement-
Play Games

知其然,知其所以然。在上一篇博文中我們聊到 微服務的本質 就是一種新的協作機制,可以加速分工、促進合作,但為什麼微服務有這種效用呢?今天我們來聊聊其背後的原因。 ...


知其然,知其所以然。在上一篇博文中我們聊到 微服務的本質 就是一種新的協作機制,可以加速分工、促進合作,但為什麼微服務有這種效用呢?今天我們來聊聊其背後的原因。

在業務互聯網化之前,我們建設的大部分IT系統都是供內部員工使用的,主要用於提升辦公、管理的規範和效率,以及通過無紙化來降低辦公成本等。但現在互聯網已經成為獲客、銷售和服務的載體,跟以往相比,業務形態的變化越來越快,也越來越多樣化。原先我們經年累月在物理世界構築起的防禦城牆,例如:廣告渠道(廣播電視或戶外等)、銷售網路(代理人或實體店等)、客服中心等,都被互聯網瞬間推平了,這完全是降維打擊。

行業邊界變得越來越模糊,跨界競爭越來越白熱化,在這個沒有天然屏障的世界里贏者真的可以通吃。在這個巨變不斷的時代,再睿智的管理者也無法預見業務的發展,要不然各行各業不會出現這麼多新巨頭。就像在兩眼抹黑的環境下,我們只能小步前行,不斷創新、迭代和試錯。天下武功唯快不破,內在的夢想和外在的壓力,呼喚更加精細的分工、更加廣密的合作,只有這樣才能提升進化的速度,從而更好地適應不斷變化的外部環境。

  • 領域驅動設計讓分工更加高效

為什麼說微服務可以加速分工呢?單體式架構的特點就是不同類型的業務邏輯混雜在一起,彼此之間沒有明顯的物理邊界,所有人都在維護同一個代碼庫,耦合度非常高。在業務需要快速迭代的當下,每次發版本都要全量回歸測試,無法並行開發,這樣很難提升速度。微服務化就是藉助領域驅動設計(DDD)理論將單體式拆解成多個彼此獨立的業務組件,高內聚低耦合,每個組件聚焦各自業務,避免變更範圍無法有效控制。

除此之外,著名的“康威理論”告訴我們:組織架構決定了系統架構,每個微服務組件都應該由一個小而精的團隊維護,最適合的團隊規模就是“兩張披薩”可以吃飽的人數。通過限制代碼和人員的規模,微服務讓業務更聚焦、分工更精細、組織更簡單、溝通更高效。

  • 交互機制標準化讓合作更簡單

沒有分工就沒有合作,如果每個人的才能相似,又乾同樣的活,那合作的必要性就降低了,更多是競爭。為什麼微服務可以促進合作呢?我們可以將合作的雙方抽象成兩個節點,合作就是在兩個節點之間建立連線。在單體式時代,系統間的交互存在許多協議,例如:EJB T3、RMI、SOAP、Dubbo、Hessian 等,跟不同的系統通訊需要依賴不同的協議,這種情況下學習、溝通和維護成本都很高,不利於合作。而微服務將通訊協議統一為HTTP,組件或系統間的交互全部採用RESTful API,報文以JSON為編碼格式,同時引進服務註冊、發現等機制。這些技術理念都是借鑒自世界上最大的合作網路:互聯網,包括超文本傳輸協議HTTP、功能變數名稱系統DNS。簡單、統一和松耦合的機制有利於合作。

因此,微服務可以幫我們加速分工、促進合作。在微服務架構下,軟體的復用率更高,研發的並行性也更高,從而以更快的迭代速度打磨出更好的產品,在更高的質量屬性保障下全天候服務全網用戶,同時資源利用更精細高效,讓我們的產品具備更好的成本優勢。撥開雲霧,看清微服務的本質,找到我們學習新技術的內驅力。

當然,微服務想要發揮最佳的效果,必須要跟容器雲和DevOps結合,應用所依賴的其他服務最好是雲化的,例如:傳統的網路存儲方案NAS就需要改為雲存儲,這樣應用和關聯服務都具備彈性伸縮能力,在業務量爆發性增長的情況下,系統能夠快速地擴容,無需從頭到尾手工擴容。記住一句話:微服務,就是加速分工、促進合作,讓我們進化得更快!

堅持原創不易,如果你覺得有價值,麻煩動動手指點下文 「 推薦 」按鈕,讓更多小伙伴可以看到,老兵哥會更有動力堅持分享的。另外,我後續還會分享職業規劃、應聘面試、技能提升、影響力打造等經驗,歡迎 關註 本專欄或微信公眾號 「 IT老兵哥 」

關註「IT老兵哥」,賦能程式人生

近期熱評文章:架構師入門系列


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

-Advertisement-
Play Games
更多相關文章
  • 過濾選擇器 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <ul> <li>我是第1個li</li> <li>我是第2個li</li> <li ...
  • vue項目在控制臺中報這個錯誤時,當看到nextTick詞時想到vue的$nextTick()方法 Vue 在更新 DOM 時是非同步執行的。只要偵聽到數據變化,Vue 將開啟一個隊列,並緩衝在同一事件迴圈中發生的所有數據變更,也就是說,vue賦一個值,並不是立即生效,而是下一個事件觸發時更新 為了在 ...
  • 大家在開發項目中是否遇到過數據延遲,舉個例子 你點某個功能 會有 1-2s的延遲,這1-2s可能會在你的頁面顯示一個一直轉著圈圈的動畫,不知道有沒有小伙伴還不知道這個功能是如何實現的呢?其實在一個項目中 這是非常常見的,如果你使用的有 element ,element上有個 loading 熟悉 它 ...
  • 基本選擇器 名稱用法描述 ID選擇器 $(“#id”); 獲取指定ID的元素 類選擇器 $(“.class”); 獲取同一類class的元素 標簽選擇器 $(“div”); 獲取同一類標簽的所有元素 並集選擇器 $(“div,p,li”); 使用逗號分隔,只要符合條件之一就可。 交集選擇器 $(“d ...
  • 大家是否有印象,在開發項目中,我們往往會把axios給封裝起來,寫在一個js文件夾里,最後引入的也是js文件夾,而不是直接對axios進行操作,那為什麼? 1. 如果一個組件需要請求數據,就要用到axios進行請求數據,但這樣會加大項目對axios這個包的依賴,一旦需要改變請求方式,改起來會很麻煩, ...
  • umi 是一個企業級 react 應用框架,也是螞蟻金服的底層前端框架 《螞蟻金服的前端框架和工程化實踐》 一、安裝腳手架 在創建項目之前,需要保證有 node 8.10 以上的環境 可以使用官方腳手架 create-umi 快速創建項目 首先創建一個新目錄 mkdir myapp && cd m ...
  • 給自己博客添加看板娘 此版本不但有不同的看板娘形象,還有多套衣服可以選擇搭配,具備聊天功能等 好了,廢話不多講先給大家展示一下,這是用看板娘自帶的照相功能下載的幾張圖片 這就是其中幾個小可愛的樣子了,看完之後有沒有把她們帶到自己博客的想法??教程在下麵 第一步 首先下載配置文件,文件目錄如下 下載地 ...
  • 一、axios的基本用法 <router-link to="" class="a1" @click.native="logins">登陸</router-link> 這三個直接請求 Axios.get() Axios.post() Axios({}) 創建一個axios實例,沒有發送請求,creat ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...