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

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

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

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]刪除
最新教學 更多>
  • 如何克服PHP的功能重新定義限制?
    如何克服PHP的功能重新定義限制?
    克服PHP的函數重新定義限制在PHP中,多次定義一個相同名稱的函數是一個no-no。嘗試這樣做,如提供的代碼段所示,將導致可怕的“不能重新列出”錯誤。 但是,PHP工具腰帶中有一個隱藏的寶石:runkit擴展。它使您能夠靈活地重新定義函數。 runkit_function_renction_...
    程式設計 發佈於2025-04-06
  • Java是否允許多種返回類型:仔細研究通用方法?
    Java是否允許多種返回類型:仔細研究通用方法?
    在Java中的多個返回類型:一種誤解類型:在Java編程中揭示,在Java編程中,Peculiar方法簽名可能會出現,可能會出現,使開發人員陷入困境,使開發人員陷入困境。 getResult(string s); ,其中foo是自定義類。該方法聲明似乎擁有兩種返回類型:列表和E。但這確實是如此嗎...
    程式設計 發佈於2025-04-06
  • 如何在鼠標單擊時編程選擇DIV中的所有文本?
    如何在鼠標單擊時編程選擇DIV中的所有文本?
    在鼠標上選擇div文本單擊帶有文本內容,用戶如何使用單個鼠標單擊單擊div中的整個文本?這允許用戶輕鬆拖放所選的文本或直接複製它。 在單個鼠標上單擊的div元素中選擇文本,您可以使用以下Javascript函數: function selecttext(canduterid){ if(d...
    程式設計 發佈於2025-04-06
  • 如何實時捕獲和流媒體以進行聊天機器人命令執行?
    如何實時捕獲和流媒體以進行聊天機器人命令執行?
    在開發能夠執行命令的chatbots的領域中,實時從命令執行實時捕獲Stdout,一個常見的需求是能夠檢索和顯示標準輸出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    程式設計 發佈於2025-04-06
  • 如何使用替換指令在GO MOD中解析模塊路徑差異?
    如何使用替換指令在GO MOD中解析模塊路徑差異?
    在使用GO MOD時,在GO MOD 中克服模塊路徑差異時,可能會遇到衝突,其中可能會遇到一個衝突,其中3派對軟件包將另一個帶有導入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    程式設計 發佈於2025-04-06
  • Python讀取CSV文件UnicodeDecodeError終極解決方法
    Python讀取CSV文件UnicodeDecodeError終極解決方法
    在試圖使用已內置的CSV模塊讀取Python中時,CSV文件中的Unicode Decode Decode Decode Decode decode Error讀取,您可能會遇到錯誤的錯誤:無法解碼字節 在位置2-3中:截斷\ uxxxxxxxx逃脫當CSV文件包含特殊字符或Unicode的路徑逃...
    程式設計 發佈於2025-04-06
  • 如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    為有效的slug生成首先,該函數用指定的分隔符替換所有非字母或數字字符。此步驟可確保slug遵守URL慣例。隨後,它採用ICONV函數將文本簡化為us-ascii兼容格式,從而允許更廣泛的字符集合兼容性。 接下來,該函數使用正則表達式刪除了不需要的字符,例如特殊字符和空格。此步驟可確保slug僅包...
    程式設計 發佈於2025-04-06
  • 如何干淨地刪除匿名JavaScript事件處理程序?
    如何干淨地刪除匿名JavaScript事件處理程序?
    刪除匿名事件偵聽器將匿名事件偵聽器添加到元素中會提供靈活性和簡單性,但是當要刪除它們時,可以構成挑戰,而無需替換元素本身就可以替換一個問題。 element? element.addeventlistener(event,function(){/在這里工作/},false); 要解決此問題,請考...
    程式設計 發佈於2025-04-06
  • 如何使用Regex在PHP中有效地提取括號內的文本
    如何使用Regex在PHP中有效地提取括號內的文本
    php:在括號內提取文本在處理括號內的文本時,找到最有效的解決方案是必不可少的。一種方法是利用PHP的字符串操作函數,如下所示: 作為替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式來搜索特...
    程式設計 發佈於2025-04-06
  • 為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    查詢模式實現缺失:解決“無法找到”錯誤在Silverlight應用程序中,嘗試使用LINQ建立LINQ連接以錯誤而實現的數據庫”,無法找到查詢模式的實現。”當省略LINQ名稱空間或查詢類型缺少IEnumerable 實現時,通常會發生此錯誤。 解決問題來驗證該類型的質量是至關重要的。在此特定實例...
    程式設計 發佈於2025-04-06
  • 如何使用PHP將斑點(圖像)正確插入MySQL?
    如何使用PHP將斑點(圖像)正確插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call fil...
    程式設計 發佈於2025-04-06
  • 為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    網格超過身體,用100%grid-template-columns 為什麼在grid-template-colms中具有100%的顯示器,當位置設置為設置的位置時,grid-template-colly修復了? 問題: 考慮以下CSS和html: class =“ snippet-code”> ...
    程式設計 發佈於2025-04-06
  • 如何將多種用戶類型(學生,老師和管理員)重定向到Firebase應用中的各自活動?
    如何將多種用戶類型(學生,老師和管理員)重定向到Firebase應用中的各自活動?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    程式設計 發佈於2025-04-06
  • 如何限制動態大小的父元素中元素的滾動範圍?
    如何限制動態大小的父元素中元素的滾動範圍?
    在交互式接口中實現垂直滾動元素的CSS高度限制問題:考慮一個佈局,其中我們具有與用戶垂直滾動一起移動的可滾動地圖div,同時與固定的固定sidebar保持一致。但是,地圖的滾動無限期擴展,超過了視口的高度,阻止用戶訪問頁面頁腳。 $("#map").css({ margin...
    程式設計 發佈於2025-04-06
  • 如何在php中使用捲髮發送原始帖子請求?
    如何在php中使用捲髮發送原始帖子請求?
    如何使用php 創建請求來發送原始帖子請求,開始使用curl_init()開始初始化curl session。然後,配置以下選項: curlopt_url:請求 [要發送的原始數據指定內容類型,為原始的帖子請求指定身體的內容類型很重要。在這種情況下,它是文本/平原。要執行此操作,請使用包含以下標頭...
    程式設計 發佈於2025-04-06

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

Copyright© 2022 湘ICP备2022001581号-3