”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 您应该了解的顶级微服务设计模式

您应该了解的顶级微服务设计模式

发布于2024-11-01
浏览:535

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]删除
最新教程 更多>
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-05-05
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-05-05
  • 在Oracle SQL中如何提取下划线前的子字符串?
    在Oracle SQL中如何提取下划线前的子字符串?
    [ 在oracle sql 解决方案: Explanation:SUBSTR function extracts a substring starting from the specified position (0) and continuing for a specified length.IN...
    编程 发布于2025-05-05
  • Java中如何使用观察者模式实现自定义事件?
    Java中如何使用观察者模式实现自定义事件?
    在Java 中创建自定义事件的自定义事件在许多编程场景中都是无关紧要的,使组件能够基于特定的触发器相互通信。本文旨在解决以下内容:问题语句我们如何在Java中实现自定义事件以促进基于特定事件的对象之间的交互,定义了管理订阅者的类界面。以下代码片段演示了如何使用观察者模式创建自定义事件: args)...
    编程 发布于2025-05-05
  • 如何在php中使用卷发发送原始帖子请求?
    如何在php中使用卷发发送原始帖子请求?
    如何使用php 创建请求来发送原始帖子请求,开始使用curl_init()开始初始化curl session。然后,配置以下选项: curlopt_url:请求 [要发送的原始数据指定内容类型,为原始的帖子请求指定身体的内容类型很重要。在这种情况下,它是文本/平原。要执行此操作,请使用包含以下标头...
    编程 发布于2025-05-05
  • 如何将多种用户类型(学生,老师和管理员)重定向到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-05-05
  • 如何在其容器中为DIV创建平滑的左右CSS动画?
    如何在其容器中为DIV创建平滑的左右CSS动画?
    通用CSS动画,用于左右运动 ,我们将探索创建一个通用的CSS动画,以向左和右移动DIV,从而到达其容器的边缘。该动画可以应用于具有绝对定位的任何div,无论其未知长度如何。问题:使用左直接导致瞬时消失 更加流畅的解决方案:混合转换和左 [并实现平稳的,线性的运动,我们介绍了线性的转换。这...
    编程 发布于2025-05-05
  • 如何高效地在一个事务中插入数据到多个MySQL表?
    如何高效地在一个事务中插入数据到多个MySQL表?
    mySQL插入到多个表中,该数据可能会产生意外的结果。虽然似乎有多个查询可以解决问题,但将从用户表的自动信息ID与配置文件表的手动用户ID相关联提出了挑战。使用Transactions和last_insert_id() 插入用户(用户名,密码)值('test','test...
    编程 发布于2025-05-05
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, AttributeError: SomeClass...
    编程 发布于2025-05-05
  • 左连接为何在右表WHERE子句过滤时像内连接?
    左连接为何在右表WHERE子句过滤时像内连接?
    左JOIN CONUNDRUM:WITCHING小时在数据库Wizard的领域中变成内在的加入很有趣,当将c.foobar条件放置在上面的Where子句中时,据说左联接似乎会转换为内部连接。仅当满足A.Foo和C.Foobar标准时,才会返回结果。为什么要变形?关键在于其中的子句。当左联接的右侧值...
    编程 发布于2025-05-05
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-05-05
  • 如何在Java的全屏独家模式下处理用户输入?
    如何在Java的全屏独家模式下处理用户输入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    编程 发布于2025-05-05
  • 如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在“ dd/mm/yyyy hh:mm:mm:ss.ss”格式“ gormat 解决方案:的,请访问量很大,并应为procectiquiestate的,并在整个代码上正确格式不多: java.text.simpledateformat; 导入java.util.calendar; 导入java...
    编程 发布于2025-05-05
  • Java开发者如何保护数据库凭证免受反编译?
    Java开发者如何保护数据库凭证免受反编译?
    在java 在单独的配置文件保护数据库凭证的最有效方法中存储凭据是将它们存储在单独的配置文件中。该文件可以在运行时加载,从而使登录数据从编译的二进制文件中远离。使用prevereness class import java.util.prefs.preferences; 公共类示例{ 首选项...
    编程 发布于2025-05-05
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在Silverlight应用程序中,尝试使用LINQ建立LINQ连接以错误而实现的数据库”,无法找到查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中...
    编程 发布于2025-05-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3