」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Spring Cloud 的微服務架構

使用 Spring Cloud 的微服務架構

發佈於2024-07-29
瀏覽:862

Microservices Architecture with Spring Cloud

微服務架構是一種設計方法,其中應用程式由鬆散耦合的服務組成。每個服務負責特定的功能,並且可以獨立開發、部署和擴充。 Spring Cloud 是一套工具和框架,有助於建立健壯且可擴展的微服務。

什麼是微服務?
微服務將複雜的應用程式分解為更小的、可管理的服務。每個微服務都專注於單一業務功能,並透過明確定義的 API(通常使用 REST 或訊息佇列)與其他服務進行通訊。

微服務的好處

  • 可擴展性:各個服務可依需求獨立擴展。
  • 靈活性:可以使用不同的技術和語言開發不同的服務。
  • 故障隔離:一項服務故障,不會影響整個系統。
  • 持續部署:實現服務的頻繁且獨立的部署。

Spring Cloud的關鍵組件

1. Spring Cloud 配置:

  • 集中外部配置管理。
  • 支援Git、SVN、本機檔案等多種設定來源。
  • 範例:跨多個服務配置資料庫憑證、API 金鑰和其他屬性。

2. Spring Cloud Netflix:

  • 整合了Eureka、Hystrix、Zuul、Ribbon等Netflix OSS元件。
  • Eureka:服務發現伺服器和客戶端。
  • Hystrix:用於容錯的斷路器。
  • Zuul:用於動態路由的API網關。
  • Ribbon:客戶端負載平衡。

3. Spring Cloud Gateway:

  • 取代 Zuul 的新專案。
  • 提供了一個簡單有效的方式來路由請求。
  • 路徑重寫、負載平衡、路由過濾等功能。

4。 Spring Cloud Sleuth:

  • 分散式追蹤以追蹤微服務之間的請求流。
  • 與 Zipkin 整合進行監控和分析。

5。 Spring Cloud Stream:

  • 建構事件驅動的微服務的架構。
  • 使用 RabbitMQ 和 Apache Kafka 等訊息傳遞系統。

使用 Spring Cloud 建立簡單的微服務應用程式:

設定 Spring Boot 專案:

  • 為每個微服務創建單獨的 Spring Boot 專案。
  • 在pom.xml或build.gradle中定義Spring Cloud元件的依賴關係。

配置 Spring Cloud Config Server:

  • 設定配置伺服器來管理外部配置。
  • 將微服務指向Config Server進行集中配置。

使用 Eureka 進行服務發現:

  • 設定Eureka伺服器用於服務註冊和發現。
  • 配置各微服務註冊到Eureka伺服器。

API 閘道與 Spring Cloud Gateway:

  • 設定 Spring Cloud Gateway 用於將請求路由到不同的微服務。
  • 定義處理請求的路由規則和過濾器。

使用 Hystrix 加入彈性:

  • 整合 Hystrix 以實現熔斷和回退機制。
  • 使用@HystrixCommand註解方法以啟用熔斷。

使用 Spring Cloud Sleuth 進行分散式追蹤:

  • 新增 Sleuth 依賴項以追蹤和記錄請求流。
  • 使用 Zipkin 視覺化和分析追蹤數據。

範例:實作簡單的微服務架構

讓我們考慮一個具有以下微服務的基本電子商務應用程式:

  1. 產品服務:管理產品資訊。
  2. 訂單服務:處理訂單和交易。
  3. 庫存服務:管理庫存水準。

第 1 步:建立 Spring Boot 專案
對於每個服務,建立一個具有必要相依性的 Spring Boot 專案:


org.springframework.cloudspring-cloud-starter-netflix-eureka-client

第 2 步:設定設定伺服器
建立一個配置伺服器並將其配置為從 Git 儲存庫讀取:

# application.yml for Config Server
spring:
  cloud:
    config:
      server:
        git:
          uri: https://github.com/your-repo/config-repo

第 3 步:向 Eureka 註冊服務
在每個微服務中,配置Eureka客戶端設定:

# application.yml for Product Service
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

第4步:設定Spring Cloud Gateway
在網關應用程式中設定路由:

# application.yml for Gateway
spring:
  cloud:
    gateway:
      routes:
        - id: product-service
          uri: lb://PRODUCT-SERVICE
          predicates:
            - Path=/products/**

第 5 步:使用 Hystrix 新增斷路器
註釋服務類別中的方法:

@HystrixCommand(fallbackMethod = "fallbackMethod")
public String getProductDetails(String productId) {
    // logic to get product details
}

public String fallbackMethod(String productId) {
    return "Product details not available";
}

第 6 步:啟用分散式追蹤
新增 Sleuth 和 Zipkin 依賴項和配置:

# application.yml for Tracing
spring:
  zipkin:
    base-url: http://localhost:9411/

結論

使用 Spring Cloud 實現微服務架構可以增強應用程式的可擴展性、彈性和可維護性。 Spring Cloud 強大的工具集簡化了建置和管理微服務的複雜性,使其成為開發人員的絕佳選擇。透過遵循最佳實踐並利用這些強大的工具,您可以創建高效、可擴展且容錯的微服務解決方案。

版本聲明 本文轉載於:https://dev.to/vidhi_jayswal/microservices-architecture-with-spring-cloud-lff?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何使用sync.WaitGroup防止Go並發死鎖?
    如何使用sync.WaitGroup防止Go並發死鎖?
    解決 Goroutines 死鎖在這種情況下,您在 Go 並發代碼中遇到了死鎖錯誤。讓我們深入研究這個問題並提供一個有效的解決方案。 該錯誤是由於生產者和消費者的行為不匹配而發生的。在生產者函數中實現的生產者在有限的時間內在通道 ch 上發送值。然而,存在於主函數中的消費者無限期地運行,無休止地嘗試...
    程式設計 發佈於2024-11-02
  • 如何處理文字檔案中的 Unicode 文字:無錯誤編寫的完整指南
    如何處理文字檔案中的 Unicode 文字:無錯誤編寫的完整指南
    文本文件中的Unicode 文本:無錯誤寫作綜合指南從Google 文件中提取的編碼資料可能具有挑戰性,尤其是當遇到需要轉換為HTML 使用的非ASCII 符號時。本指南提供了處理 Unicode 文字並防止編碼錯誤的解決方案。 最初,在資料檢索期間將所有內容轉換為 Unicode 並將其寫入檔案似...
    程式設計 發佈於2024-11-02
  • EchoAPI 與 Insomnia:結合實例進行綜合比較
    EchoAPI 與 Insomnia:結合實例進行綜合比較
    作为一名全栈开发人员,我知道拥有一流的工具来调试、测试和记录 API 是多么重要。 EchoAPI 和 Insomnia 是两个出色的选项,每个选项都有自己独特的特性和功能。让我带您了解这些工具,比较它们的功能和优点,给您一些实际示例,并帮助您决定何时使用 EchoAPI 或 Insomnia。 ...
    程式設計 發佈於2024-11-02
  • 出發時間和持續時間|程式設計教學
    出發時間和持續時間|程式設計教學
    介紹 本實驗旨在測試您對 Go 的時間和持續時間支援的理解。 時間 下面的程式碼包含如何在 Go 中使用時間和持續時間的範例。但是,程式碼的某些部分遺失了。您的任務是完成程式碼,使其按預期工作。 Go程式語言基礎知識。 熟悉 Go 的時間和持續時間支援。 $ ...
    程式設計 發佈於2024-11-02
  • 起重面試問答
    起重面試問答
    1. JavaScript 中什么是提升? 答案: 提升是执行上下文创建阶段为变量和函数分配内存的过程。在此过程中,为变量分配了内存,并为变量分配了值 undefined。对于函数,整个函数定义存储在内存中的特定地址,并且对其的引用放置在该特定执行上下文中的堆栈上。 ...
    程式設計 發佈於2024-11-02
  • 了解 JavaScript 中的文件物件模型 (DOM)
    了解 JavaScript 中的文件物件模型 (DOM)
    你好,神奇的 JavaScript 開發者? 瀏覽器提供了一個稱為文檔物件模型 (DOM) 的程式設計接口,它允許腳本(特別是 JavaScript)與網頁佈局進行互動。網頁的文檔物件模型 (DOM) 是一種分層樹狀結構,它將頁面的元件排列成對象,由瀏覽器在載入時建立。借助此範例,...
    程式設計 發佈於2024-11-02
  • 開始使用 SPRING BATCH 進行編程
    開始使用 SPRING BATCH 進行編程
    Introduction Dans vos projets personnels ou professionnels, Il vous arrive de faire des traitements sur de gros volumes de données. Le traite...
    程式設計 發佈於2024-11-02
  • 使用 CSS 讓您的 Github 個人資料脫穎而出
    使用 CSS 讓您的 Github 個人資料脫穎而出
    以前,自訂 Github 個人資料的唯一方法是更新圖片或更改名稱。這意味著每個 Github 設定檔看起來都一樣,自訂它或脫穎而出的選項很少。 從那時起,您可以選擇使用 Markdown 建立自訂部分。您可以包括您的履歷、您的興趣和嗜好,讓您的個人資料反映您的身分。這是任何人在訪問您的個人資料時看...
    程式設計 發佈於2024-11-02
  • TypeScript 實用程式類型:增強程式碼可重複使用性
    TypeScript 實用程式類型:增強程式碼可重複使用性
    TypeScript 提供內建實用程式類型,讓開發人員有效地轉換和重複使用類型,讓您的程式碼更加靈活和 DRY。在本文中,我們將探討關鍵實用程式類型,例如 Partial、Pick、Omit 和 Record,以協助您將 TypeScript 技能提升到新的水平。 Partial:使所有屬性可選 ...
    程式設計 發佈於2024-11-02
  • 電報 window.open(url, &#_blank&#);在ios上工作很奇怪
    電報 window.open(url, &#_blank&#);在ios上工作很奇怪
    我正在製作一個電報機器人,我想添加將一些資訊從小型應用程式轉發到聊天的選項。我決定使用 window.open(url, '_blank');在我在 iPhone 上嘗試之前它一直運作良好。我沒有轉發,而是分享(這是一件大事,我正好需要轉發一條訊息)。我有一些如何處理它的想法,但它們...
    程式設計 發佈於2024-11-02
  • 誰是前端開發人員?
    誰是前端開發人員?
    當今網路上每個網站或平台的使用者介面部分都是前端開發人員工作的結果。他們參與創建用戶友好的介面,確保網站的外觀和功能。但到底誰是前端開發人員呢?我簡單解釋一下。 用戶看到的部分是前端 開啟網站時首先看到的是網頁介面:顏色、按鈕、文字、動畫。這都是由前端開發人員創建的。前端是網站或應...
    程式設計 發佈於2024-11-02
  • 如何使用保留的 CSS 樣式將 HTML 內容儲存為 PDF?
    如何使用保留的 CSS 樣式將 HTML 內容儲存為 PDF?
    使用CSS 將HTML 內容儲存為PDF在Web 開發中,即使將內容匯出為不同格式,保持視覺美觀也至關重要。當嘗試將 HTML 元素儲存為 PDF 時,這可能會帶來挑戰,因為 CSS 樣式可能會在轉換過程中遺失。 對於必須在已儲存的PDF 中保留CSS 的情況,請考慮使用以下方法:建立新視窗: 開啟...
    程式設計 發佈於2024-11-02
  • 為什麼使用 Print_r() 時要為 DateTime 物件新增幻像屬性?
    為什麼使用 Print_r() 時要為 DateTime 物件新增幻像屬性?
    Print_r() 變更 DateTime 物件Print_r() 在 DateTime 物件上新增屬性,以便在偵錯期間啟用自省。此行為是 PHP 5.3 中引入的內部功能的副作用,它將幻像公共屬性指派給轉儲到文字的實例。 要避免這些屬性所造成的錯誤,請改用反射。然而,不建議尋找這些屬性,因為它們沒...
    程式設計 發佈於2024-11-02
  • C 語言的資料結構與演算法:適合初學者的方法
    C 語言的資料結構與演算法:適合初學者的方法
    在 C 語言中,資料結構和演算法用於組織、儲存和操作資料。資料結構:陣列:有序集合,使用索引存取元素鍊錶:透過指標連結元素,支援動態長度堆疊:先進後出(FILO) 原則佇列:先進先出(FIFO) 原則樹:分級組織資料演算法:排序:依特定順序排序元素搜尋:在集合中尋找元素圖形:處理節點與邊之間的關係實...
    程式設計 發佈於2024-11-02
  • ## `has_key()` 還是 `in`?  在 Python 中檢查字典鍵的最佳方法是什麼?
    ## `has_key()` 還是 `in`? 在 Python 中檢查字典鍵的最佳方法是什麼?
    在Python 中選擇「has_key()」和「in」來檢查字典鍵當涉及驗證是否存在Python 字典中的特定鍵,「has_key()」和「in」都提供了可行的選項。然而,首選方法隨著時間的推移而演變。 歷史上,「has_key()」通常用來檢查字典中鍵是否存在。然而,此函數已在 Python 3....
    程式設計 發佈於2024-11-02

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3