如何正確使用 Spring Cloud?【中】

来源:https://www.cnblogs.com/itlaobingge/archive/2019/12/05/11987713.html
-Advertisement-
Play Games

從 2004 年發佈 1.0 版本開始,Spring 目前已經演進至 5.x 版本了,為不同時期的應用開發提供了強有力的支撐。現在我們正面對微服務、DevOps、雲計算這些新的挑戰,Spring 家族的新生力量 Spring Cloud 又將給我們提供哪些方面的支撐呢? ...


3. Spring 集成了哪些常用組件?

從 2004 年發佈 1.0 版本開始,Spring 目前已經演進至 5.x 版本了,為不同時期的應用開發提供了強有力的支撐。現在我們正面對微服務、DevOps、雲計算這些新的挑戰,Spring 家族的新生力量 Spring Cloud 又將給我們提供哪些方面的支撐呢?概括起來說,我覺得主要分為四類:

  • 在單個微服務的構建上,它提供了一套應用開發框架,主體是基於 Spring Framework 這個生態的開源產品。
  • 在水平維度服務集成上,它以 Starter 的方式集成了大量常用組件和微服務全家桶,達到開箱即用,降低我們開發微服務的難度,提升效率,避免重覆投入。
  • 在垂直維度資源調度上,它可以跟 Cloud Foundry、Kubernetes、Docker 等平滑集成,讓應用上雲更加簡單,讓資源調度變得更加智能高效,讓應用具備更大的彈性。
  • 在研發流程全線連通上,它可以跟 DevOps 相關係統做一些配合和優化,以便應用能夠更加順暢地通過各個研發環節,讓持續集成、持續交付更加高效。

接下來,我們將展開每個點來看一看。首先,我們來看一下它究竟集成了一些什麼樣的常用組件:

  • 監控服務類,包括主機監控(Vector)、應用監控(Actuator)等;
  • 存儲服務類,包括關係型資料庫(MySQL)、文檔型資料庫(MangoDB)、記憶體型資料庫(Redis)等;
  • 消息服務類,包括 ActiveMQ、RocketMQ、Kafka 等;
  • 安全服務類,包括 OAuth2.0、JWT 等。

4. Spring Cloud 微服務全家桶有哪些?

除了常用組件之外,Spring Cloud 還集成了微服務全家桶,開箱即用:

  • 服務註冊發現類,包括:Eureka、Consul、Zookeeper、Etcd 等;

服務註冊:每個微服務組件都向註冊中心登記自己提供的服務,包括服務的主機、埠號、版本號、通訊協議等信息。註冊中心按照服務類型分類組織服務清單,同時以心跳檢測的方式監測清單中服務是否可用,若不可用需要從服務清單中剔除,以達到排除故障服務的效果。

服務發現:在服務治理框架下,服務間的調用不再通過具體的實例地址來實現,而是通過服務名發起請求調用實現。服務調用方通過服務名從註冊中心的服務清單中獲取服務實例的列表清單,通過指定的負載均衡策略取出一個服務實例位置來進行服務調用。

  • 服務調用框架類,包括:Ribbon、Feign 等;

客戶端負載均衡,將負載均衡邏輯集成到消費方,消費方從註冊中心獲知服務有哪些實例可用,然後再按照某種策略從這些地址中選擇一個服務實例進行訪問。

  • 服務容錯組件類,包括:Hystrix 等;

服務熔斷:某個目標服務不可用或大量訪問超時,系統將斷開該服務的調用,對後續的調用請求,系統不再繼續轉發至此服務,直接返回失敗應答,從而快速地釋放資源;如果目標服務情況好轉,則恢復調用。服務降級:在應急屏蔽或服務熔斷情況下,直接返回本地預設的應答。

  • 統一配置中心類,包括:Spring Cloud Config、Spring Cloud Bus 等;

在服務構建階段,配合構建流水線,為服務軟體包或鏡像提供配置;在服務運維階段,動態調整服務配置,滿足運維的靈活性需求;在服務開發階段,提供配置 API 將配置外置化,供其他系統調用。

  • 服務網關代理類,包括:Zuul、Spring Cloud Gateway 等;

主要提供服務路由功能,即接收消費方的所有請求,按照某種策略將請求轉發至服務提供方。同時,在服務網關中完成一系列橫切麵的功能,例如:許可權校驗、請求計量、流量控制、服務質量、請求管理、響應管理、版本管理等。

  • 調用鏈路監測類,包括:Spring Cloud Sleuth,封裝了 Dapper、Zipkin 和 HTrace 等;

微服務架構下組件的數量眾多,一個業務請求可能需要調用多個服務,調用的複雜性決定了錯誤和異常難以定位。我們需要知道每個請求到底有哪些服務參與,調用順序是怎麼樣的,從而清楚每個調用步驟,出現問題也能很快定位。

通常我們會採用 Eureka 作為服務註冊中心,實現服務註冊與發現;通過 Ribbon 和 Feign 實現服務的消費以及客戶端負載均衡;通過 Spring Cloud Config 實現應用不同環境的外部化配置以及版本管理。為了讓服務集群更為健壯,藉助 Hystrix 的融斷機制來避免微服務架構中個別服務出現異常時引起故障蔓延和雪崩。服務網關 Zuul 為微服務架構門戶,將許可權控制、計量計費等較重的非業務邏輯內容遷移到服務路由層面,使得服務集群主體能夠具備更高的可復用性和可測試性。

本文主要價值是幫助大家梳理出 Spring Cloud 相關的知識框架,也就是我們常說的全局視角或者上帝視角。有了這個框架之後,我們可以根據自己的需要按圖索驥找相關節點的資料來研究學習,不至於陷入細節找不到方向。當然,考慮到我們每個人的工作學習情況不同,平時遇到的問題也不同,本文內容無法覆蓋所有人遇到的問題,歡迎大家留言提問,也歡迎關註「 IT老兵哥 」交流互動,謝謝!

本系列其他文章索引如下:


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

-Advertisement-
Play Games
更多相關文章
  • 本文由葡萄城技術團隊於博客園翻譯並首發 轉載請註明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。 如果我們自己編寫從URL中分析和提取元素的代碼,那麼有可能會比較痛苦和麻煩。程式員作為這個社會中最“懶”的群體之一,無休止的重覆造輪子必然是令人難以容忍的,所以大多數瀏 ...
  • 條件語句用於基於不同條件執行不同的動作。 條件語句 在您寫代碼時,經常會需要基於不同判斷執行不同的動作。 您可以在代碼中使用條件語句來實現這一點。 在 JavaScript 中,我們可使用如下條件語句: 使用 if 來規定要執行的代碼塊,如果指定條件為 true 使用 else 來規定要執行的代碼塊 ...
  • 案例1:點擊按鈕禁用文本框 <input type="button" value="禁用文本框" id="btn" /> <input type="text" value="文本框" id="txt" /> <script> document.getElementById("btn").onclic ...
  • part1複習 JavaScript分三個部分: 1. ECMAScript標準 JS基本的語法 2. DOM:Document Object Model 文檔對象模型 3. BOM:瀏覽器對象模型 DOM的作用: 操作頁面的元素 DOM樹: 把html頁面或者是xml文件看成是一個文檔,文檔就是一 ...
  • 安裝完上述插件之後,就可以進行引用了 如果源碼出現以下錯誤:則說明sass版本過高,只需要調為較低版本即可。實證有效版本:7.3.1 修改之後刪除 文件夾 然後 重新下載 即可 TypeError: this.getResolve is not a function ...
  • 一、寫在前頭 接到某廠電話問什麼是事件代理的時候,一開始說addEventListener,然後他說直接綁定新的元素不會報dom不存在的錯誤嗎?然後我就混亂了,我印象中這個方法是可以綁定新節點的。後面才知道,原來他要考察的是事件委托(代理)的原理,他指的是未來還不清楚會創建多少個節點,所以沒辦法實現 ...
  • 首先是typeorm的官方地址, 國內有人翻了中文版,不保證時效性 ·通過npm安裝下列包: typeorm //typeorm連接資料庫 @types/node //類型系統 typescript //ts基礎 oracledb //oracle基礎 ts-node //nodejs編譯運行ts的 ...
  • 慕課網 實戰班 就業班 2019年12月5號 更新資料整理 300套 百度網盤資料鏈接: 鏈接:https://pan.baidu.com/s/1qORPsgM6ukDPOSjU5ck5yA提取碼:qnlu複製這段內容後打開百度網盤手機App,操作更方便哦 微雲鏈接: https://docs.qq ...
一周排行
    -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數據源,以確保數據隔離和安全性。 ...