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

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

相关文章

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

SprinBoot+Vue网络商城海鲜市场的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质创作者,全网30w+