微服務實戰——微服務架構選型SpringCloud / Dubbo / K8S比較(一)

来源:https://www.cnblogs.com/qupengkun/archive/2020/03/31/12607562.html
-Advertisement-
Play Games

說在前面 大概是三年前,因一些原因公司原項目最初為單體結構部署,所有業務模塊都在一個項目裡面,而後隨著業務的不斷膨脹以及模塊之間的耦合,導致後面增加或修改一些簡單業務時的成本都會變的極大。新入職的同事更是苦不堪言,學習代碼的成本極高。基於這些原因,就開始了後面漫長的架構改造旅途。 這麼多微服解決方案 ...


說在前面

大概是三年前,因一些原因公司原項目最初為單體結構部署,所有業務模塊都在一個項目裡面,而後隨著業務的不斷膨脹以及模塊之間的耦合,導致後面增加或修改一些簡單業務時的成本都會變的極大。新入職的同事更是苦不堪言,學習代碼的成本極高。基於這些原因,就開始了後面漫長的架構改造旅途。

這麼多微服解決方案,到底選哪個?

1.介紹

file

  • Motan 微博內部使用的 RPC 框架,於 2016 年對外開源。後來在 Motan Agent 的基礎上演化出了 WeiboMesh,這裡暫時不展開說Motan GitHub

  • Dubbo 阿裡巴巴開源,一款高性能、輕量級的開源Java RPC框架,它提供了三大核心能力:面向介面的遠程方法調用,智能容錯和負載均衡,以及服務自動註冊和發現。曾經有很長一段時間未維護,現已貢獻至Apache基金會孵化。附上鏈接Dubbo官網

  • SpringCloud 由Pivotal 公司 2014 年開源,利用 Spring Boot 特性整合了開源行業中優秀的組件(如Netflix相關組件),整體對外提供了一套在微服務架構中服務治理的解決方案。與Dubbo都經常被使用且比較,這次主要是基於SpringCloud基礎組件集成

  • Kubernetes 全新的基於容器技術的分散式架構方案。用於管理雲平臺中多個主機上的容器化的應用,Kubernetes的目標是讓部署容器化的應用簡單並且高效(powerful),Kubernetes提供了應用部署,規劃,更新,維護的一種機制

2.對比(話不多說,直接上圖)

file

3.選擇

很幸運的是,上圖三種技術棧都有用過。算是各有優劣吧,具體還是要結合實際情況去選擇,不過千萬註意的是儘量別混搭(如SpringCloud+K8S或SpringCloud+Dubbo這樣)

後面具體會先圍繞SpringCloud技術棧展開,而後也會記錄下k8s和Dubbo相關的一些東西。這是第一篇,後面開始實戰,以上!

結束

  • 關於環境
    file)
  • 架構圖
    file

持續學習,記錄點滴。更多文章請訪問 文章首發


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

-Advertisement-
Play Games
更多相關文章
  • 什麼是 XHTML?XHTML 是以 XML 格式編寫的 HTML。 XHTML 指的是可擴展超文本標記語言 XHTML 與 HTML 4.01 幾乎是相同的 XHTML 是更嚴格更純凈的 HTML 版本 XHTML 是以 XML 應用的方式定義的 HTML XHTML 是 2001 年 1 月發佈 ...
  • 首先保證這些條件滿足: 然後全局安裝vue cnpm install -g vue-cli 安裝完成後可以使用vue -h查看vue的幫助文檔 vue -list 查看vue支持的模板 我們接下來會用到的是webpack vue init webpack mall 項目名輸入必須是英文,我這裡輸入m ...
  • HTML URL代表HTML 統一資源定位器(Uniform Resource Locators),URL是一個網頁地址,URL可以由字母組成,如"W3CSchools.cc",或互聯網協議(IP)地址: 192.68.20.50;大多數人進入網站使用網站功能變數名稱來訪問,因為 名字比數字更容易記住。 U ...
  • 關於object標簽,現在已經很少使用了,但在考慮到相容性的問題上,還是會用到object標簽的。 在對object標簽的使用中,會出現播放視頻的 object 標簽遮蓋住其他 div 標簽,使其不能正常顯示。 1 <div class="btn-group" style="width:100px; ...
  • jquery 動畫 隱藏與顯示 1. hide(ms,callback)——隱藏 2. show()——顯示 3. toggle()——隱藏或者顯示 + 可以帶一個整數參數,表示動畫的時間;callback參數表示回調函數 + 動畫效果是向左上角收縮或打開的。 淡入淡出 1. fadeIn(ms,c ...
  • 官方文檔:React 中一個常見模式是為一個組件返回多個元素。Fragments 可以讓你聚合一個子元素列表,並且不在DOM中增加額外節點。 作用:代替div作為外層的包裹層。 Fragments看起來像是一個空的標簽。 render() { return ( <> <ChildA /> <Chil ...
  • 官網 http://mint-ui.github.io/#!/zh-cn 安裝 cnpm install mint-ui -S 在main.js中引入改插件 Toast效果演示: 查看文檔 在頁面中調用插件 Message box效果演示: 這是移動端插件,所以調整到移動端演示: 底部tabbar演 ...
  • 聊聊服務發現註冊 服務多,迭代快是微服務的明顯特征。那麼在快速小版本迭代業務時,如果按照傳統的方式發佈更新服務,手動的修改一些服務與服務之間的調用關係是非常麻煩且累人的。一個典型的場景可能是,一個微服務升級迭代之後,硬體環境發生改變(IP等的變化)。傳統的做法是修改與其有調用關係的微服務調用地址然後 ...
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...