【微服務架構】微服務概念及SpringCloud組件介紹(一)

来源:https://www.cnblogs.com/iUtopia/archive/2019/09/09/11492072.html
-Advertisement-
Play Games

簡要介紹微服務架構及其特點,並引入Spring Cloud與其中一部分核心組件。 ...


一、微服務架構

1、微服務架構簡介

  1.1、分散式:不同的功能模塊部署在不同的伺服器上,減輕網站高併發帶來的壓力。

  1.2、集群:多台伺服器上部署相同應用構成一個集群,通過負載均衡共同向外提供服務。

  1.3、微服務:微服務架構模式就是將web應用拆分為一系列小的服務模塊,這些模塊可以獨立地編譯、部署,並通過各自暴露的API介面通訊,共同組成一個web應用。

  1.4、SpringCloud是基於SpringBoot的一整套微服務框架,提供了一系列可配置的組件,如配置管理服務發現負載均衡熔斷器斷路器智能路由微代理控制匯流排全局鎖決策競選分散式會話集群狀態管理等。

2、微服務的特點

  • 單一職責:每一個服務模塊都對應單一的業務實現
  • 微:服務拆分的顆粒度很小
  • 面向服務:每個服務對外僅暴露服務介面API即可,不關心服務的技術實現,與技術、語言和平臺無關
  • 自治:服務間互相獨立、互不幹擾
    • 團隊獨立
    • 技術獨立:提供Rest介面,面向服務即可
    • 前後端分離
    • 資料庫分離:每個服務使用自己的數據源
    • 部署獨立:每個服務都是獨立的組件,可復用,可替換,降低服務間的耦合

3、三者的關係

微服務是一種結構理念,設計原則,提供理論指導;

Spring Boot專註於快速、方便集成的單個微服務個體,可以基於Spring Boot快速開發單個微服務;

Spring Cloud是一個基於Spring Boot實現的服務工具治理包,專註於全局的服務治理框架。

二、Spring Cloud

1、Spring Cloud組件架構

 

上圖中各組件的組件和運行流程如下:

    • 所有請求都通過API網關來訪問內部服務;
    • 網關接受請求後,從註冊中心獲取可用服務模塊;
    • 由Ribbon進行負載均衡後,分發到後臺的具體實例;
    • 各個服務模塊之間通過Feign進行通信處理業務;
    • Hystrix負責處理服務超時熔斷;
    • Turbine監控服務間的調用和熔斷相關指標。

再來看一個具體實例上的Spring Cloud服務流程:

2、Spring Cloud組件簡介

2.1、主要組件簡介

  • Eureka,服務註冊中心
  • Zuul,API服務網關
  • Config,分散式配置中心,支持本地倉庫、SVN、Git、Jar包內配置等模式
  • Dashboard,Hystrix儀錶盤,監控集群模式和單點模式,其中集群模式需要收集器Turbine配合
  • Ribbon,客戶端負載均衡
  • Feign,聲明式服務調用
  • Bus,消息匯流排

2.2、組件主要功能

Eureka和Ribbon,一個註冊服務,一個消費服務。

  Hystrix,為了優化Ribbon,防止整個微服務架構因為某個服務節點的問題導致崩潰,起到保險絲的作用。

Dashboard,給Hystrix統計和展示用,而且監控服務節點的整體壓力和健康情況。

  Turbine,集群收集器,服務於Dashboard。

Zuul,加在整個微服務最前沿的防火牆和代理器,隱藏微服務結點IP埠信息,加強安全保護。

Config,為瞭解決所有微服務各自維護各自的配置,設置一個統一的配置中心,方便修改配置。

  Bus是因為config修改完配置後各個結點都要refresh才能生效實在太麻煩,所以交給bus來通知服務節點刷新配置的。


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

-Advertisement-
Play Games
更多相關文章
  • 前面介紹了通過JDBC如何管理資料庫,當時提到Statement專門提供了executeQuery方法用於查詢操作,為什麼查詢操作這麼特殊呢?這是因為其它語句跑完一次就了事了,頂多像insert、update、delete再返回受影響的記錄數量,但select命令跟它們不一樣,查詢語句可能會返回多條 ...
  • 項目 內容 這個作業屬於哪個課程 https://www.cnblogs.com/nwnu-daizh/ 這個作業的要求在哪裡 https://www.cnblogs.com/nwnu-daizh/p/11475377.html 作業學習目標 第一部分:結合Java和C基礎語法的異同比較,總結本周理 ...
  • 左值和右值:左值:用的是對象的身份(記憶體中的位置),右值:用的是對象的值(內容) 解引用與遞增(遞減)運算符連用: *ivec++:取ivec當前值並向後移動一個元素,等價於*(ivec++),本來++的優先順序高於* 條件運算符嵌套:(註意在語句兩端加上括弧,條件運算符優先順序極低) A?B:C?D: ...
  • 1變數、運算符和類型轉換:1.1手動輸入一個學生的成績,對這個成績進行一次加分,加當前成績的20%,輸出加分後成績 Scanner scan = new Scanner(System.in); System.out.println("請輸入一個數字"); int num = scan.nextInt ...
  • pycharm快捷鍵 變數 什麼是變數 變數: 定義世間萬物變化的狀態 IPO I input 輸入(變數) P Process 處理 O Output 輸出 變數的組成 1. 變數名:具有描述意義; 接受變數值 2. 賦值符號:賦值,把變數值傳給變數名 3. 變數值:具體的值 變數名的規範 1. ...
  • Django之Models的class Meta 作者:@skyflask轉載本文請註明出處:https://www.cnblogs.com/skyflask/p/9544898.html 目錄 1、abstract2、app_label3、db_table4、db_tablespace5、defa ...
  • java中的所有map都實現了Map介面,以下方法適用於任何map實現(HashMap, TreeMap, LinkedHashMap, Hashtable, 等等)。 1 HashMap map = new HashMap(); 2 map.put(1, "jack"); 3 map.put(2,... ...
  • 本文介紹使用Git初始化本地倉庫,並首次提交代碼到遠程倉庫GitLab上面。 首先,登錄GitLab,創建一個新項目的私人倉庫; 然後,在本地倉庫(就是你寫代碼文件夾),右鍵,Git Bash Here,打開Git命令視窗; 在Git命令視窗輸入 git init,初始化本地倉庫,初始化完成後,本地 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...