」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 您應該了解的頂級微服務設計模式

您應該了解的頂級微服務設計模式

發佈於2024-11-01
瀏覽:529

Top icroservices Design Patterns You Should Know

构建可扩展、可维护且具有弹性的系统需要了解重要的设计模式,这些模式在微服务架构中变得越来越普遍。与整体架构相反,微服务将大型系统划分为更易于管理的独立服务,这些服务通过网络相互连接。然而,这种分布式特性在通信、数据管理和服务协调等领域带来了复杂性。

采用众所周知的微服务设计模式可以帮助缓解这些问题并显着提高系统的可靠性和有效性。本文介绍了每个软件开发人员都应该了解的 7 种最重要的微服务设计模式。

1。 API网关模式

API 网关充当所有客户端对微服务请求的单一入口点。 API 网关不是让客户端直接与多个服务交互,而是整合这些请求,将它们路由到适当的微服务,并聚合响应。它简化了客户端-服务器通信,并提供了一种管理横切问题的方法,例如身份验证、日志记录和速率限制。

好处:

✓ 对请求/响应处理的集中控制。

✓ 通过抽象内部微服务复杂性来简化客户端交互。

✓ 更轻松地实现安全、缓存和限制。

例子:

在Node.js中使用Express.js构建一个基本的API网关:

import express from 'express';
import proxy from 'express-http-proxy';

const app = express();

// Forward requests to microservice A
app.use('/serviceA', proxy('http://serviceA-url'));

// Forward requests to microservice B
app.use('/serviceB', proxy('http://serviceB-url'));

app.listen(3000, () => {
  console.log('API Gateway running on port 3000');
});

2.断路器模式

在微服务架构中,服务失败是不可避免的。断路器模式通过监视服务调用并在达到特定故障阈值时停止对失败服务的进一步调用,帮助防止级联故障。一旦服务恢复,断路器就允许再次调用。这提高了系统弹性并防止本已陷入困境的服务承受不必要的负载。

好处:

✓ 防止系统范围内的故障。

✓ 在失败期间提供后备或替代响应。

✓ 增强微服务架构的稳健性。

例子:

在 Node.js 中使用 opossum 库作为断路器:

import CircuitBreaker from 'opossum';
import axios from 'axios';

const options = {
  timeout: 5000,
  errorThresholdPercentage: 50,
  resetTimeout: 30000,
};

const circuitBreaker = new CircuitBreaker(() => axios.get('http://serviceB-url'), options);

circuitBreaker.fire()
  .then(response => console.log(response.data))
  .catch(err => console.log('Service B is down. Circuit is open.'));

3.每个服务模式的数据库

每个微服务应该有自己的专用数据库,允许团队独立工作并减少服务之间的紧密耦合。这种设计模式确保微服务可以独立发展,而不会受到共享数据库架构更改的影响。

好处:

✓ 减少跨服务依赖和争用。

✓ 促进独立扩展和模式演化。

✓ 隔离数据所有权和责任。

4。传奇模式

在分布式架构中,处理跨多个服务的事务可能具有挑战性。 Saga 模式使用一系列跨多个服务协调的本地事务来管理分布式事务。每个服务执行其事务并触发下一个事务,并通过补偿机制在出现问题时撤消操作。

好处:

✓ 无需集中式事务管理器即可实现一致的分布式事务。

✓ 支持跨微服务的最终一致性。

✓ 必要时启用未完成操作的回滚。

例子:

在电子商务系统中,订单服务可能创建订单,付款服务处理付款,库存服务更新库存水平。如果支付失败,需要回滚订单和库存更新,通过补偿交易来处理。

5。事件溯源模式

事件溯源模式将系统的状态存储为事件序列。微服务不是将当前状态保存在数据库中,而是存储表示状态更改的事件。通过重播这些事件,始终可以重建当前状态,从而提供完整的审计跟踪并启用复杂的恢复机制。

好处:

✓ 提供所有变更的清晰审计跟踪。

✓ 通过重播过去的事件来启用历史分析。

✓ 如有必要,有利于重建状态。

例子:

在会计系统中,“交易创建”、“交易批准”和“交易完成”等事件被存储为事件。通过回放所有交易事件,可以重新计算当前余额。

6。 CQRS(命令查询职责分离)模式

CQRS 模式将读取和写入操作分为不同的模型。写操作由命令模型处理,读操作由查询模型处理。此模式对于读取比写入频繁得多的高性能应用程序特别有用。

好处:

✓ 通过分离读/写问题来优化性能。

✓ 支持不同的读写扩展策略。

✓ 允许针对特定任务定制灵活的模型。

7.绞杀无花果图案

Strangler Fig 模式是一种渐进式迁移策略,允许您用微服务重构或替换单体的部分内容。随着新功能的添加,它被构建为微服务。随着时间的推移,单体系统会被逐个服务地替换,而不会立即中断整个系统。

好处:

✓ 提供从整体迁移到微服务的无中断路径。

✓ 降低整个系统重写的风险。

✓ 实现增量改进和重构。

例子:

您可以首先将整体应用程序的用户身份验证组件提取到独立的微服务中,同时保持系统其他部分完好无损。随着时间的推移,更多的组件被转移到微服务中,直到整个系统实现模块化。

结论

使用微服务设计原则时,有许多不同的方法可以解决分布式系统中出现的问题。构建可靠、可扩展的微服务架构需要掌握这些模式,无论您的目标是什么——跨服务管理数据、增强服务之间的通信或优雅地处理错误。通过解决特定的要求和权衡,这些模式都有助于提高微服务的弹性和性能。

版本聲明 本文轉載於:https://dev.to/wallacefreitas/top-7-microservices-design-patterns-you-should-know-3c16?1如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • 如何使用 mysqli_pconnect() 在 PHP 中實作 MySQL 連線池?
    如何使用 mysqli_pconnect() 在 PHP 中實作 MySQL 連線池?
    MySQL 的 PHP 連線池在 PHP 中,維護資料庫連線會影響效能。為了優化這一點,開發人員經常考慮使用連接池技術。 MySQL 的連線池MySQL 沒有內建的連線池機制。然而,MySQLi 擴充功能提供了mysqli_pconnect() 函數,其作用與mysqli_connect() 類似,...
    程式設計 發佈於2024-11-07
  • 將 HTMX 加入 GO
    將 HTMX 加入 GO
    HTMX 是 intercooler.js 的後繼者,用於使用 HTTP 指令擴充 HTML,而無需編寫 API。現在,我知道一開始我說我要刪除抽象層,但是我更多的是系統/工具程式設計師,所以我仍然需要一些抽象,直到我掌握了底層實際發生的情況。 基本概念 HTMX 部署 AJAX ...
    程式設計 發佈於2024-11-07
  • 發現 itertools
    發現 itertools
    Itertools 是最有趣的 Python 函式庫之一。它包含一系列受函數式語言啟發的函數,用於與迭代器一起使用。 在這篇文章中,我將提到一些最引起我注意並且值得牢記的內容,以免每次都重新發明輪子。 數數 好幾次我都實現了無限數(好吧,結束了 明確地在某一點用中斷)使用 whi...
    程式設計 發佈於2024-11-07
  • 為什麼每個人都應該學習 Go(即使您認為生活中不需要另一種語言)
    為什麼每個人都應該學習 Go(即使您認為生活中不需要另一種語言)
    啊,Go,编程语言。您可能听说过,也许是从办公室里一位过于热情的开发人员那里听说过的,他总是不停地谈论他们的 API 现在有多“快得惊人”。当然,您已经涉足过其他语言,也许您会想:“我真的需要另一种语言吗?”剧透警报:是的,是的,你知道。 Go 就是那种语言。让我以最讽刺、最真诚的方式为你解释一下。...
    程式設計 發佈於2024-11-07
  • 如何計算 Pandas 中多列的最大值?
    如何計算 Pandas 中多列的最大值?
    在Pandas 中尋找多列的最大值假設您有一個包含多列的資料框,並且希望建立一個包含兩個或多個列中的最大值的新列現有的列。例如,給定A 列和B 列,您需要建立C 列,其中:C = max(A, B)要完成此任務:使用max 函數和axis=1 計算指定列中每行的最大值:df[["A&quo...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中從目錄中檢索檔案名稱?
    如何在 PHP 中從目錄中檢索檔案名稱?
    從 PHP 中的目錄中擷取檔案如何在 PHP 中存取目錄中的檔案名稱?事實證明,確定正確的命令具有挑戰性。這個問題旨在為尋求類似解決方案的個人提供幫助。 PHP提供了幾種從目錄獲取文件清單的方法:DirectoryIterator(建議)此類允許對目錄中的文件進行迭代:foreach (new Di...
    程式設計 發佈於2024-11-07
  • 使用 Linq、Criteria API 和 Query Over 擴充 NHibernate 的 Ardalis.Specification
    使用 Linq、Criteria API 和 Query Over 擴充 NHibernate 的 Ardalis.Specification
    Ardalis.Specification is a powerful library that enables the specification pattern for querying databases, primarily designed for Entity Framework Cor...
    程式設計 發佈於2024-11-07
  • PYTHON:OOP {初學者版}
    PYTHON:OOP {初學者版}
    Python:物件導向程式設計[OOP]:是一種程式設計範式(模型),使用物件和類別來建立軟體一種模擬現實世界實體和關係的方法。這是基於物件可以包含資料和操作該資料的程式碼的想法。 關於物件導向編程,您需要了解一些關鍵概念: 班級 目的 屬性 方法 遺產 封裝 多態性 抽象 下面的範例是一個幫助您...
    程式設計 發佈於2024-11-07
  • Neo.mjs:一個高效能開源 JavaScript 框架。
    Neo.mjs:一個高效能開源 JavaScript 框架。
    在瀏覽 GitHub 並尋找可協作的開源專案時,我發現了 Neo.mjs。我對這個計畫產生了興趣,並開始更多地研究這個新框架。我想在這篇文章中分享我發現的所有內容。 什麼是 Neo.mjs? Neo.mjs 旨在建立高效能、資料驅動的 Web 應用程序,重點在於利用 Web Wor...
    程式設計 發佈於2024-11-07
  • 將 Azure Functions 部署到 Azure 容器應用程式的兩種方法的比較
    將 Azure Functions 部署到 Azure 容器應用程式的兩種方法的比較
    昨天,我寫了一篇題為「在 Azure 容器應用程式上部署 Java Azure Function」的文章。 在那篇文章中,我提到使用 Azure 的整合管理功能,我想澄清這意味著什麼以及它與本文中先前的方法有何不同。 舊方法:使用 az containerapp create 創...
    程式設計 發佈於2024-11-07
  • 如何使用 MinGW 在 Windows 上建置 GLEW?逐步指南。
    如何使用 MinGW 在 Windows 上建置 GLEW?逐步指南。
    使用MinGW 在Windows 上建立GLEW:綜合指南使用GLEW,這是一個無縫整合OpenGL 和WGL 函數的純頭文件庫,使用MinGW 增強Windows 上OpenGL 應用程式的開發。為了使用 MinGW 有效建置 GLEW,需要一組特定的命令和步驟。 首先,建立兩個名為 lib 和 ...
    程式設計 發佈於2024-11-07
  • 如何使用 CSS 創建帶有對角線的雙色調背景?
    如何使用 CSS 創建帶有對角線的雙色調背景?
    使用對角線創建雙色調背景要使用CSS 實現由對角線分為兩部分的背景,請執行以下操作這些步驟:1。建立兩個 Div:建立兩個單獨的 div 來表示兩個背景部分。 2.設定 Div 樣式:將下列 CSS 套用至 div:.solid-div { background-color: [solid co...
    程式設計 發佈於2024-11-07
  • 文件的力量:閱讀如何改變我在 JamSphere 上使用 Redux 的體驗
    文件的力量:閱讀如何改變我在 JamSphere 上使用 Redux 的體驗
    作為開發人員,我們經常發現自己一頭扎進新的庫或框架,渴望將我們的想法變為現實。跳過文件並直接跳到編碼的誘惑很強烈——畢竟,這有多難呢?但正如我透過建立音樂管理平台 JamSphere 的經驗所了解到的那樣,跳過這一關鍵步驟可能會將順利的旅程變成充滿挑戰的艱苦戰鬥。 跳過文檔的魅力 ...
    程式設計 發佈於2024-11-07
  • 如何在PHP多子網域應用中精準控制Cookie域?
    如何在PHP多子網域應用中精準控制Cookie域?
    在PHP 中控制Cookie 域和子域在PHP 中控制Cookie 域和子域建立多子網域網站時,必須控制會話cookie 的網域確保每個子網域的正確會話管理。然而,手動設定網域時,PHP 的 cookie 處理似乎存在差異。 header("Set-Cookie: cookiename=c...
    程式設計 發佈於2024-11-07
  • 如何取得已安裝的 Go 軟體包的完整清單?
    如何取得已安裝的 Go 軟體包的完整清單?
    檢索Go 中已安裝軟體包的綜合清單在多台電腦上傳輸Go 軟體包安裝時,有必要取得詳細的清單所有已安裝的軟體包。本文概述了此任務的簡單且最新的解決方案。 解決方案:利用“go list”與過時的答案相反,當前的建議列出Go 中已安裝的軟體包是使用“go list”命令。透過指定三個文字句點 ('...
    程式設計 發佈於2024-11-07

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

Copyright© 2022 湘ICP备2022001581号-3