微服务架构七种模式

news/2024/7/4 7:48:11 标签: 架构, 微服务, 云原生

微服务架构七种模式

  • 目录
    • 概述
      • 需求:
    • 设计思路
    • 实现思路分析
  • 参考资料和推荐阅读

Survive by day and develop by night.
talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
happy for hardess to solve denpendies.

目录

在这里插入图片描述

概述

微服务架构七种模式

需求:

1.聚合器微服务设计模式
2. 代理微服务设计模式
3. 链式微服务设计模式
4. 分支微服务设计模式
5. 数据共享微服务设计模式
6. 异步消息传递微服务设计模式

设计思路

1.聚合器微服务设计模式
其主要功能是将不同的微服务功能模块组合成一个单一的API,从而提高整个系统的可用性和可扩展性。
具体来说,聚合器微服务设计模式的实现需要以下步骤:

对于需要聚合的功能模块,使用独立的微服务进行开发和维护,并尽可能地保持每个服务的独立性和可扩展性;

设计一个聚合器微服务,该服务将调用所有需要的功能模块,并将它们的响应结果汇总成一个单一的API响应。这个聚合器微服务可以被视为一个路由器,它将路由所有的请求到正确的服务;

当聚合器微服务收到一个请求时,它会调用所有需要的功能模块,并将它们的响应结果汇总成一个单一的API响应。这个响应结果可以是JSON格式的数据,也可以是其他格式的数据;

对于特定的业务需求,可以在聚合器微服务中实现各种聚合逻辑,例如对多个响应结果进行组合、聚合或过滤等等。

  1. 代理微服务设计模式

安全代理:代理微服务可以在客户端和后端服务之间提供安全层,对数据进行加密、身份验证和授权等操作,确保只有授权的用户可以访问服务。

负载均衡代理:代理微服务可以根据负载情况动态分配请求到多个后端实例,以避免某个实例过载从而导致服务不可用的情况。

缓存代理:代理微服务可以在客户端和后端服务之间提供缓存层,从而提高服务的响应速度和性能。

带宽限制代理:代理微服务可以限制对后端服务的访问速率,从而避免后端服务因过多请求而崩溃。

记录数据代理:代理微服务可以对所有请求和响应数据

  1. 链式微服务设计模式
    链式微服务设计模式是一种可扩展的设计模式
    该模式将各个微服务连接起来,形成一条链,每个微服务都完成一部分功能,然后将结果传递给下一个服务,直到完成整个过程。

该模式将各个微服务连接起来,形成一条链,每个微服务都完成一部分功能,然后将结果传递给下一个服务,直到完成整个过程。

在链式微服务设计模式中,每个微服务都是独立的,它们都有自己的输入和输出,并且可以使用异步消息传递或同步调用等不同的通信方式。每个微服务都是可插拔的,可以轻松添加或删除服务,而不需要修改整个系统。

这种设计模式允许每个微服务专注于自己的任务,而不需要关注整个系统的细节。它还可以提高系统的可扩展性和性能,因为每个微服务都可以进行水平扩展,以处理更多的请求。

另外,链式微服务设计模式可以帮助开发人员更好地组织代码和模块化系统。每个微服务都可以作为一个模块,可以单独测试和部署,从而更容易实现持续交付和部署。

分支微服务设计模式是一种用于构建大型系统的微服务架构模式,它将系统分成多个小的、相互独立的子系统。

在分支微服务设计模式中,每个微服务代表一个子系统,负责处理该子系统的所有业务逻辑。这种模式允许每个子系统独立开发、测试和部署,从而提高了系统的可伸缩性和可维护性。

  1. 分支微服务设计模式
    分支微服务设计模式主要有以下几个特点:

  2. 每个微服务都是独立的,具有自己的数据库和API接口。

  3. 不同的微服务之间可以通过RESTful API或消息队列进行通信。

  4. 每个微服务都遵循单一职责原则,只负责处理特定的业务逻辑。

  5. 分支微服务模式允许系统中的不同部分独立开发和升级,从而提高了系统的可伸缩性和可维护性。

  6. 通过使用分支微服务模式,可以将系统中的风险降到最低,因为每个微服务都可以独立测试和部署。

数据共享微服务是一种模式,它允许不同的应用程序和服务共享数据,以便实现更高效的业务流程。下面是一些常用的数据共享微服务设计模式:

数据聚合模式:将多个数据源的数据聚合到一个中心库或数据湖中,并提供统一的API接口供其他服务调用。

数据复制模式:将数据从一个数据源复制到另一个数据源,以便在不同的应用程序或服务中使用。

数据传输模式:使用消息队列或其他数据交换机制,将数据从一个服务传输到另一个服务。

数据缓存模式:使用缓存服务将数据缓存起来,以便其他服务可以更快地访问它们。

数据仓库模式:构建一个数据仓库,将数据从多个数据源导入其中,并提供查询接口供其他服务使用。

异步消息传递是一种常见的微服务设计模式,它允许不同的服务之间通过消息传递进行通信。这种方式可以帮助解决微服务架构中的耦合性和性能问题。

在异步消息传递模式中,一个服务可以通过消息队列向另一个服务发送消息,而不需要直接调用该服务的 API。这种方式可以让服务之间解耦,因为发送方不需要知道接收方的实现细节,只需要知道如何发送消息,并且接收方会在消息队列中接收并处理消息。

另外,异步消息传递还可以提高系统的性能和可伸缩性。因为消息队列可以处理大量的消息,不同的服务可以异步地处理这些消息,从而让整个系统的吞吐量得到提高
以下是异步消息传递微服务设计模式的几个关键要点:

1.使用消息队列作为服务之间通信的中介。消息队列可以是开源的,比如RabbitMQ和Apache Kafka,也可以是云服务商提供的管理的消息队列,比如AWS SQS和Azure Service Bus。

2.定义标准的消息格式和协议,以确保不同的服务可以理解和处理消息。

3.使用异步方式发送消息,这意味着发送方不需要等待接收方处理完消息才能继续执行。

4.确保消息处理的幂等性,即使同一个消息被处理多次,也应该保证最终结果是一样的。

实现思路分析

参考资料和推荐阅读

参考资料
官方文档
开源社区
博客文章
1.https://edu.iask.sina.com.cn/jy/3o7lgs8RzuF.html
书籍推荐

欢迎阅读,各位老铁,如果对你有帮助,点个赞加个关注呗!同时,期望各位大佬的批评指正~


http://www.niftyadmin.cn/n/4989813.html

相关文章

win10 ping不通 Docker ip(解决截图)

背景: win10下载了docker desktop就是这个图,然后计划做一个springboot连接docker。 docker部署springboot :docker 部署springboot(成功、截图)_總鑽風的博客-CSDN博客 问题:spring boot部署docker后,docker接口通了&#xff0…

「网络」1.不知的浏览器缓存精品答案

前言:你真的懂浏览器缓存吗 文章目录 强缓存协商缓存协商缓存可以基于两种头部来实现。小结 🚀 作者简介:作为某云服务提供商的后端开发人员,我将在这里与大家简要分享一些实用的开发小技巧。在我的职业生涯中积累了丰富的经验&am…

C语言常见字符串和内存函数详解

字符串和内存函数 1. 前言2. 求字符串长度2.1 strlen 3. 长度不受限制的字符串函数3.1 strcpy3.2 strcat3.3 strcmp 4. 长度受限制的字符串函数4.1 strncpy4.2 strncat4.3 strncmp 5. 字符串查找5.1 strstr5.2 strtok 6. 错误信息报告6.1 strerror 7. 字符操作函数7.1 字符分类…

django/CVE-2017-12794XSS漏洞复现

docker搭建漏洞复现环境 漏洞原理看帮助文档 # Django debug page XSS漏洞(CVE-2017-12794)分析Django发布了新版本1.11.5,修复了500页面中可能存在的一个XSS漏洞,这篇文章说明一下该漏洞的原理和复现,和我的一点点评…

IDEA全局统一设置Maven

原来每次打开新建的项目都需要经过 File-> Settings 重新配置maven,这样很不爽 然而经过 File-> New Projects Setup -> Settings for New Projects 后,再如上图配置后就全局设置好了

Java 的线程安全机制之`synchronized`

前言:首先,线程表示一条单独的执行流,每个线程有自己的执行计数器,有自己的栈,但可以共享内存,共享内存是实现线程协作的基础,但共享内存有两个问题,竞态条件和内存可见性。解决这些…

Linux的内存理解

建议 Mysql机器 尽量不要硬swap,如果是ssd磁盘还好。Free命令 free 命令显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存 输出简介: Mem 行(第二行)是内存的使用情况。Swap 行(第三行)是交换空间的使用情况。total 列显示系统总的可用物理内存和交换…

CSS中如何实现元素的渐变背景(Gradient Background)效果?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ CSS 渐变背景效果⭐ 线性渐变背景⭐ 径向渐变背景⭐ 添加到元素的样式⭐ 写在最后 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&…