软件架构设计——微服务、伪微服务及其构造

2024-09-05 09:28

本文主要是介绍软件架构设计——微服务、伪微服务及其构造,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

微服务、伪微服务及其构造

1. 什么是微服务?

微服务是一种软件架构风格,它将应用程序拆分为多个小而独立的服务模块,每个服务模块专注于某个特定的业务功能。每个微服务独立部署、独立运行,通过网络(通常是 RESTful API)与其他微服务进行通信。这种架构具有高度的灵活性、可维护性和扩展性。

  • 业务独立性:每个微服务专注于一个业务领域,独立开发、测试、部署,减少了系统的复杂性。
  • 技术多样性:每个微服务可以使用不同的技术栈来实现,允许使用最合适的工具来解决特定的问题。
  • 弹性和容错性:微服务可以独立扩展和容错,一个服务的失败不会影响到其他服务的运行。
2. 什么是伪微服务?

伪微服务是指那些表面上看似采用微服务架构,但实际上并没有真正实现微服务的核心原则和优势的系统。典型的伪微服务往往是“披着微服务外衣的单体应用”,存在以下问题:

  • 高耦合:各个服务之间相互依赖,无法独立开发和部署。
  • 复杂通信:服务间通信复杂、频繁,增加了系统的延迟和故障点。
  • 缺乏自治:无法独立运行,某个服务故障可能导致整个系统失效。

伪微服务的核心问题在于没有清晰划分服务的边界,导致系统复杂度和维护成本远高于真正的微服务架构。

3. 如何通过 RESTful API 和分布式超媒体构建微服务生态

RESTful API 是一种通过 HTTP 协议构建 API 的风格,使用标准的 HTTP 方法(如 GET、POST、PUT、DELETE)来实现客户端与服务端的交互。分布式超媒体则通过动态链接来描述微服务之间的关系,形成一个灵活、松耦合的企业内生态系统。

  • 分布式超媒体:通过 RESTful API 实现超媒体的链接和动态导航,使得服务间能够通过链接自然地交互。例如,通过一个订单服务的 API,可以动态地获取支付服务的链接,从而实现流程的自然流转。

  • 自描述性:服务的 API 应当自包含地描述其功能和使用方法,使得其他服务能够自动发现和调用,而不需要人工干预。

  • 分布式架构的松耦合:微服务之间通过超媒体链接保持松耦合关系,使得每个服务的变动不会对其他服务产生重大影响,提升系统的弹性和可维护性。

4. 将 8X Flow 的模型转化为微服务

8X Flow 强调以业务逻辑为中心的建模方法,可以很好地转化为微服务架构。以下是转化的关键点:

  • 履约项与弹性边界:8X Flow 中的履约项可能具有独立的弹性边界,因此在转化为微服务时,可以选择将履约项作为服务边界。需要注意的是,履约项服务化并非绝对必要,只有当履约项确实需要独立扩展时才需要拆分。

  • 合同上下文作为服务边界:建议优先将合同上下文作为服务边界,划分出独立的微服务模块。这种划分方式直观且能保持业务逻辑的清晰性。例如,一个合同管理服务可以包含创建、修改、查询合同的功能,而履约上下文中的具体履约项操作可以由合同服务内部的子模块或由独立的履约服务负责。

  • URI 编排:合同上下文和履约项通常处于相同的 URI 根路径下,可以通过 URI 编排实现服务之间的自然连接。例如,/contracts/{contractId}/fulfillments/{fulfillmentId} 表示履约项作为合同的一部分,而不需要独立为服务。在需要时,可以通过调整 URI 编排方式实现履约项的服务化。

5. 微服务的具体构造步骤
  • 识别业务领域:从业务逻辑出发,识别合同上下文、履约上下文等核心业务领域,并为每个领域定义清晰的职责和边界。

  • 划分服务边界:根据识别的业务领域,划分清晰的服务边界。优先将合同上下文划分为独立服务,再根据履约项的复杂性和扩展性需求决定是否进一步拆分。

  • 设计 API:为每个微服务设计 RESTful API,定义清晰的资源路径和操作,确保 API 符合业务逻辑,并能够自然地与其他服务交互。

  • 实现超媒体导航:利用超媒体为各个服务设计动态链接,允许服务之间通过 API 自动发现和调用。例如,在合同服务中返回履约服务的链接,便于系统根据业务流转自动跳转。

  • 确保弹性和自治:设计服务时确保每个服务能够独立部署、扩展和运行,避免出现因为服务间耦合过高导致的伪微服务现象。

  • 持续优化:随着业务变化,持续优化服务边界和交互方式,确保系统始终保持灵活、松耦合的状态,适应业务需求的快速变化。

6. 总结

微服务架构通过划分清晰的服务边界,实现业务逻辑的独立性和技术多样性,以提高系统的弹性和可维护性。8X Flow 的建模方法与微服务的设计原则高度契合,能够有效将业务逻辑转化为技术实现。通过合理的服务划分、RESTful API 设计和分布式超媒体的应用,微服务能够形成一个具有高度灵活性和适应性的企业内生态系统。在实际构建时,需要始终以业务为核心,确保每一个服务的拆分都是为了更好地支持业务需求,而非为了技术而拆分。

这篇关于软件架构设计——微服务、伪微服务及其构造的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138571

相关文章

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

关于DNS域名解析服务

《关于DNS域名解析服务》:本文主要介绍关于DNS域名解析服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录DNS系统的作用及类型DNS使用的协议及端口号DNS系统的分布式数据结构DNS的分布式互联网解析库域名体系结构两种查询方式DNS服务器类型统计构建DNS域