这是微服务架构系列文章的第 3 篇

高可用性、可扩展性、故障恢复能力和性能是微服务的特征。您可以使用微服务架构模式来构建微服务应用程序,从而降低微服务失败的风险。

模式分为三层:

应用模式

应用程序模式解决了开发人员面临的问题,例如数据分解、数据维护、测试、用户界面和一些可观察性模式。

让我们回顾一下这些应用程序模式的基础知识。

分解模式

选择如何将单体系统分解为服务

  • 按业务能力分解——服务是围绕业务能力组织的。

  • 按子域分解——服务是围绕域驱动设计的子域组织的。

数据模式

  • 数据一致性——每个服务使用一个单独的数据库以确保松散耦合。为了跨服务的数据一致性,必须使用 Saga 模式。

  • 查询——每个服务使用数据库的另一个问题是某些查询需要连接来自多个服务的数据。不可能对服务的数据库执行分布式查询,因为它的数据只能通过其 API 访问。必须使用其中一种查询模式来检索分散在多个服务中的数据。

    • API 组合——对一项或多项服务进行 API 调用并汇总结果。

    • 命令查询职责分离 (CQRS) — 数据保存在一个或多个可以轻松查询的副本中。

测试模式

单个微服务更容易测试,因为它们比单体应用程序小得多。在测试不同服务是否协同工作时,重要的是要避免使用同时检查多个服务的复杂、缓慢和不稳定的端到端测试。

  • 消费者驱动的合同测试——确保服务满足客户的期望。

  • 消费者端合约测试——确保服务的客户端可以与之通信。

  • 服务组件测试——隔离服务并对其进行测试。

用户界面模式

显示与不同服务相对应的数据及其显示方式是不同团队的责任。

  • 服务器端页面片段组合——每个团队开发一个 Web 应用程序,为他们的服务实现的页面区域生成 HTML 片段。UI 团队通过在服务器端聚合特定于服务的 HTML 片段来开发页面模板。

  • 客户端 UI 组合——每个团队创建一个客户端 UI 组件,为他们的服务实现屏幕区域,例如 AngularJS 指令。通过组合多个特定于服务的 UI 组件,UI 团队实现页面骨架来构建屏幕。

可观察性模式

为了有效地运行应用程序,了解其运行时行为并解决请求失败等问题非常重要。

  • 审计日志——审计日志记录每个用户的操作。审计活动日志通常用于协助客户支持、确保合规性和检测可疑活动。

  • 应用程序指标——监控和警报是生产环境的关键组成部分。有一系列指标,例如 CPU、内存和磁盘的利用率,到服务请求的延迟和执行的请求数。指标由提供警报和可视化的指标服务收集。

应用基础架构模式

它们适用于也会影响开发的基础设施问题,例如通信、可观察性、可靠性和安全模式。

横切关注点模式

我们必须先了解关注点,才能理解横切关注点。关注点是基于其功能的系统的一部分。有两种担忧:

  • 核心关注点——它代表主要需求的单一和特定功能,例如业务逻辑。

  • 横切关注点——与次要需求相关的关注点。横切关注点是适用于整个应用程序的关注点,例如安全性和日志记录。

    • 外部化配置——在运行时,它向服务提供配置属性值,例如数据库凭据和网络位置。

    • 微服务底盘——微服务底盘是处理一系列问题的一个或一组框架,例如外部化配置、健康检查、应用程序指标、服务发现、断路器和分布式跟踪。您可以使用微服务机箱更有效地开发服务的业务逻辑。

    • 服务模板——开发人员可以通过复制源代码模板快速开始开发新服务。顾名思义,模板是一个简单的可运行服务,它实现了构建逻辑和横切关注点以及示例应用程序逻辑。

通讯模式

基于微服务的应用程序是分布式系统。微服务架构严重依赖进程间通信(IPC)。

  • 远程过程调用 (RPI) — 使用请求/回复协议发出服务请求。

  • 特定于域的协议 - 对于服务间通信,例如使用 SMTP/IMAP 的电子邮件,或使用 RTMP/HLS/HDS 的媒体流,请使用特定于域的协议。

  • 消息传递——使用异步消息传递进行服务间通信,例如 AMQP

可观察性模式

可观察性模式提供了对应用程序行为方式的洞察。诊断微服务架构的问题要困难得多。在最终将响应返回给客户端之前,请求可以在多个服务之间反弹。

  • 日志聚合——将服务活动日志写入可以执行搜索和警报的集中式日志服务器。

  • 异常跟踪——应将异常报告给异常跟踪服务,该服务对异常进行重复数据删除、警告开发人员并跟踪其解决方案。

  • 健康检查 API — 提供一个返回服务健康状况的端点。

  • 分布式跟踪——为每个外部请求提供一个 ID,并在请求在服务之间流动时对其进行跟踪。

可靠性模式

当服务不可用时,如何保证它们之间的可靠通信?

  • 断路器——断路器可用于保护跨服务调用。当一定数量的下游资源请求未能达到一定阈值时,断路器会打开。如果断路器打开,系统将很快出现故障。一段时间后,客户端会发送一些请求来检查下游服务是否已经恢复。如果有正常响应,将在健康恢复后再次发送请求。

安全模式

用户通常由微服务架构中的 API 网关进行身份验证。然后必须将用户的身份和角色传递给它调用的服务。一个常见的解决方案是使用访问令牌模式。API 网关将访问令牌(例如 JWT(JSON Web 令牌))传递给服务,服务可以验证令牌并获取有关用户的信息。

基础架构模式

它们解决了与开发之外的基础设施有关的问题,例如部署、发现和与外部 API 的通信模式。

部署模式

部署微服务有几种模式。传统上,服务以特定语言的方式打包。有两种现代部署方法。

  • 虚拟机或容器——虚拟机或容器可用于部署服务。

  • 无服务器部署——无服务器平台在您上传服务代码后执行它。自动化的自助服务平台是部署和管理服务的最佳方式。

发现模式

通常,服务需要相互通信。单体应用程序使用语言级方法或过程调用来调用其服务。传统上,分布式系统在固定的、众所周知的位置(主机和端口)运行,因此可以通过 HTTP/REST 或其他一些机制访问服务。然而,大多数基于微服务的现代应用程序都在虚拟化或容器化环境中运行,其中服务实例的数量及其位置会动态变化。

  • 自注册——服务向服务注册中心注册自己

  • 客户端发现——服务客户端从服务注册表中检索服务实例,然后在它们之间进行负载平衡。

  • 3rd Party Registration — 第三方自动向服务注册中心注册服务实例。

  • 服务器端发现——服务发现由路由器完成,路由器接收来自客户端的请求。

外部 API 模式

微服务提供的 API 粒度通常与客户端所需的不同。微服务提供的 API 通常是细粒度的,因此客户端必须与多个服务交互。每个客户端需要不同数量的数据,网络性能对每个客户端的影响也不同。

  • API Gateway — API Gateway 实现了一项服务,该服务是从外部 API 客户端进入基于微服务的应用程序的入口点。它执行请求路由、API 组合和其他功能,例如身份验证、速率限制、缓存等。

  • 前端的后端(BFF)——为每种类型的客户端创建一个单独的 API 网关。每个移动、浏览器和公共 API 团队都将拥有自己的网关,而 API 网关团队拥有公共层。

在以后的文章中,我们将详细介绍每种模式。

本文 https://jiagoushi.pro/microservices-design-patterns
讨论:知识星球【首席架构师圈】或者加微信小号【cea_csa_cto】或者加QQ群【792862318】
公众号 【jiagoushipro】
【超级架构师】
精彩图文详解架构方法论,架构实践,技术原理,技术趋势。
我们在等你,赶快扫描关注吧。
微信小号 【cea_csa_cto】
50000人社区,讨论:企业架构,云计算,大数据,数据科学,物联网,人工智能,安全,全栈开发,DevOps,数字化.

QQ群 【792862318】深度交流企业架构,业务架构,应用架构,数据架构,技术架构,集成架构,安全架构。以及大数据,云计算,物联网,人工智能等各种新兴技术。
加QQ群,有珍贵的报告和干货资料分享。

视频号 【超级架构师】
1分钟快速了解架构相关的基本概念,模型,方法,经验。
每天1分钟,架构心中熟。

知识星球 向大咖提问,近距离接触,或者获得私密资料分享。

喜马拉雅 路上或者车上了解最新黑科技资讯,架构心得。 【智能时刻,架构君和你聊黑科技】
知识星球 认识更多朋友,职场和技术闲聊。 知识星球【职场和技术】
微博 【智能时刻】 智能时刻
哔哩哔哩 【超级架构师】

抖音 【cea_cio】超级架构师

快手 【cea_cio_cto】超级架构师

小红书 【cea_csa_cto】超级架构师

谢谢大家关注,转发,点赞和点在看。

【微服务架构】微服务设计模式相关推荐

  1. 打死都要记住!微服务架构的常用设计模式!

    作者:duanxz 来源:cnblogs.com/duanxz/p/3514895.html 大家好,我每天都会在这里给大家分享一些干货内容(当然了,周末也要允许我休息一下哈).今天跟大家分享微服务架 ...

  2. Spring Cloud构建微服务架构:服务容错保护(Hystrix断路器)

    断路器 断路器模式源于Martin Fowler的Circuit Breaker一文."断路器"本身是一种开关装置,用于在电路上保护线路过载,当线路中有电器发生短路时," ...

  3. 亿级流量电商详情页系统实战:缓存架构+高可用服务架构+微服务架构

    <缓存架构+高可用服务架构+微服务架构>深入讲解了亿级流量电商详情页系统的完整大型架构.同时最重要的是,在完全真实的大型电商详情页系统架构下,全流程实战了整套微服务架构,包含了基于领域驱动 ...

  4. Spring Cloud构建微服务架构:服务注册与发现(Eureka、Consul)【Dalston版】

    Spring Cloud简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中涉及的配置管理.服务发现.断路器.智能路由.微代理.控制总线.全 ...

  5. spring cloud+dotnet core搭建微服务架构:服务发现(二)

    前言 上篇文章<手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)>实际上只讲了服务治理中的服务注册,服务与服务之间如何调用呢?传统的方式,服务A ...

  6. Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)【Dalston版】

    前言 在微服务架构中,我们将系统拆分成了一个个的服务单元,各单元应用间通过服务注册与订阅的方式互相依赖.由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服 ...

  7. Spring Cloud构建微服务架构:服务容错保护(Hystrix依赖隔离)【Dalston版】

    前言 在上一篇<Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)>中,我们已经体验了如何使用@HystrixCommand来为一个依赖资源定义服务降级逻辑.实 ...

  8. Spring Cloud构建微服务架构:服务容错保护(Hystrix断路器)【Dalston版】

    前言 在前两篇<Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)>和<Spring Cloud构建微服务架构:服务容错保护(Hystrix依赖隔离)&g ...

  9. Spring Cloud构建微服务架构:服务网关(路由配置)【Dalston版】

    在上一篇<Spring Cloud构建微服务架构:服务网关(基础)>一文中,我们通过使用Spring Cloud Zuul构建了一个基础的API网关服务,同时也演示了Spring Clou ...

  10. 微服务架构的优缺点_微服务架构DNS服务注册与发现实现原理

    微服务架构已经成为中小型企业必备的项目支撑能力,尤其互联网BATJ企业在04年已经非常成熟,在大规模的核心业务实战中总结了很多大规模服务调度与大数据集的处理方案.微服务架构中涉及到很多模块,本文以微服 ...

最新文章

  1. Computing--状态机
  2. selenium webdriver (12) -- 鼠标和键盘
  3. Python生成列表的所有子集
  4. mysql grant 表通配符_mysql如何使用GRANT表----访问控制
  5. 【Python】urllib爬取动漫图片
  6. linux 7 yum源,Linux Redhat 7 安装免费yum源
  7. [转载]函数getopt(),及其参数optind
  8. WinCE设备仿真器+虚拟串口+GPS模拟器搭建开发测试环境
  9. 2018年最新全国县级以上行政区划对应关系数据(按国家统计局网站整理)
  10. MATLAB下载安装
  11. mysql内连接去重复_MYSQL 内连接查询重复
  12. 北邮C++——破解简单密码
  13. 开关switch系列:android Switch显示文字
  14. 小红书引流推广的终极秘籍之笔记排名
  15. 全能在线APP一款开源的多功能在线学习考试智慧软件系统
  16. 判断对象是否可回收、垃圾回收算法
  17. wps里为什么没有华文楷体_如何用WPS演示做电影滚动字幕
  18. JavaScript错误类型
  19. 视频人脸检测 opencv简单应用
  20. Salesforce认证|新鲜出炉销售代表认证!

热门文章

  1. 气动调节阀常见故障作用方式
  2. 第19节 三个败家子(19)——史上最牛太守孙坚
  3. 嵩明:“整村授信”助力乡村振兴
  4. 个人英雄主义和个人品牌
  5. picoctf-Scavenger Hunt wp
  6. 【数据库】实验二~六
  7. 在Win7环境下搭建Geant4工作平台
  8. SPSS Modeler与Google地图的完美结合
  9. MySQL数据库存储价格金额使用的数据类型中float、double、decimal的区别
  10. 量化择时策略入门与实操-笔记(同花顺金融量化实验室python实现)