0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

设计微服务架构的原则

虹科网络可视化技术 2023-11-26 08:05 次阅读

微服务是一种软件架构策略,有利于改善整体性能和可扩展性。你可能会想,我的团队需不需要采用微服务,设计微服务架构有哪些原则?本文会给你一些灵感。

文章速览:

微服务设计的要素

微服务架构设计的5个原则

微服务是一种软件架构策略,将应用程序分解为一组解耦的、自治的服务。这些独立的应用服务通过API相互通信。每个服务都由其专业领域的专家团队管理,以便每个软件开发团队可以控制自己的开发周期,按照自己的时间表进行测试和部署,使用自己的企业工具和资源,加速上线时间。为了评估你的团队是否需要采用微服务架构。这里有一些值得深入讨论的细节。

一、微服务设计的要素

设计微服务架构的第一步是形势评估。开发者网站总结的十大微服务设计原则之一是单一责任原则,即每个服务只需要将其所有资源投入到微服务应用程序的一个功能中。

1.通过领域驱动设计实施微服务

软件架构师需要进行领域分析,以确定如何划分每个服务以及需要将哪些元素纳入应用堆栈中。这种领域分析被称为领域驱动设计(Domain Driven Design, DDD)。它将实体模式和聚合模式等模式应用到单个限界上下文(bounded context)中,以便以更高的计算精度来识别单个域的边界。

总之,应该围绕特定的业务功能构建每个微服务。一旦确定了领域并了解了它们的边界,就可以定义最适合应用堆栈的变量了。

2.选择技术栈

创建微服务技术栈较为特别。通常你需要使用各种工具、框架和编程语言,将它们整合成一个耦合的系统。在选择工具时考虑以下变量:

编程语言

选择用于微服务的最佳编程语言,取决于你最熟悉哪种语言、可用于所需功能的库以及每种语言提供的功能套件。显然,选择你的开发团队已经大范围使用的语言可以节省时间和精力。

根据2021年JetBrains关于微服务的调查,“用于微服务开发的三种最流行的语言是Java(41%)、JavaScript(37%)和Python(25%)”。这些流行的编程语言都有大量的在线开发者支持、成功应用开发的示例、运行环境,比如Node.JS,以及丰富的客户端库。

总之,确保所选的语言适合当前业务问题。例如,Python在数据分析中很受欢迎,而JavaScript是全栈开发的最优选择。

数据库

在为微服务架构构建的应用程序选择适合的数据库时,应将可伸缩性、可用性和安全性置于首要位置。选择一个最能支持你在微服务中计划使用的数据模型的数据库。你的技术栈应该能够处理任何应用负载,确保使用故障切换协议可用性,并保护应用免受恶意攻击。

通信

你的业务功能可能需要您的微服务使用同步的服务间通信方法执行某些操作,对于其他操作,可能需要使用异步通信。可以使用多种通信格式和协议来辅助微服务通信,包括HTTP/REST、gRPC和AMQP。

对于异步通信,使用支持消费者组的事件驱动消息代理可以提高可伸缩性和可靠性,确保应用程序能够扩展,而不会导致任何服务无法访问的情况。

监控

每个微服务团队都负责监视应用程序性能,通常使用日志记录和可观察性工具来跟踪操作。这使得开发人员和运维人员可以跟踪整个系统,如应用程序性能、消息代理流与数据库资源利用率。

在使用消息代理时,考虑使用一个日志流,其中每个微服务都可以发布消息。这样,您可以将首选的日志记录和可观察性工具连接到流,并在不减慢应用程序的情况下异步监视您的应用程序。

二、微服务架构设计的5个原则

那么,如何确保你的微服务架构可以发挥最佳作用?以下是五个微服务应用程序设计原则,可供你参考。

1.低耦合和高内聚

低耦合和高内聚可以通过前面提到的单一责任原则来解释。赋予每个领域团队单一的职责,有助于加强该领域内的内聚,使得该服务内的所有功能都在某种程度上紧密耦合。每个服务都由其自己的领域专家和工具管理,但仍然可以通过API和其他协议相互通信。这有点像来自不同部门的同事如何互动:当有助于完成工作时,大家彼此分享信息,而不会过多地谈论与他人无关的细节。

2.适应性

业务应用程序很少是静止不变的。随着新的业务需求的出现,行业的假设发生变化,技术能力提供更多功能,软件也会发生变化。微服务应该具有可适应性,以满足新需求出现时可以进行适应。世界在变化,人们在变化,所以软件也应该变化。

3.基础设施自动化

实现微服务的一个原因是它们能够自动化流程,从而提高整体可扩展性。借助 Kubernetes 等容器编排系统,您可以使用单个镜像与微服务一起部署微服务的整个数据库。在Kubernetes控制器的帮助下,这些可移植性优势可以帮助DevOps团队管理、调度和编排自动容器部署。

4.离散边界

实施微服务要求在任何给定应用程序中的服务都要维护自己的分散数据。服务边界应该将与任何单个服务相关的所有逻辑和数据与应用程序中的其他服务隔离开。

这也是允许容器化微服务进行独立部署的逻辑。这个原则也有一些反对者,他们认为这会导致数据冗余激增。但建立这些明确的边界最大的好处之一是:当一个微服务承载自己的数据时,任何奇怪的行为都被限制在微服务内部。

5.为故障而设计

干扰是经常发生的,应用服务会在毫无征兆的情况下瘫痪。例如,挖掘机开挖光缆中断网络操作,人们会忘记续订域名,系统会因防火墙故障引起的数据连接问题而中断等。所以,需要尽力考虑潜在的故障的可实施对策。设计具有弹性的解决方案,比如使用断路器模式,以防止当某个微服务无法执行给定操作时其他服务中断。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 软件
    +关注

    关注

    67

    文章

    4350

    浏览量

    85625
  • 架构
    +关注

    关注

    1

    文章

    484

    浏览量

    25200
  • 微服务
    +关注

    关注

    0

    文章

    117

    浏览量

    7240
收藏 人收藏

    评论

    相关推荐

    【算能RADXA微服务器试用体验】Radxa Fogwise 1684X Mini 规格

    通过网络可以了解到,算能RADXA微服务器的具体规格: 处理器:BM1684X 算力:高达32Tops INT8峰值算力 内存:16GB LPDDR4X 内存 存储:64GB eMMC 编程框架
    发表于 02-28 11:21

    游戏公司不使用微服务架构的原因

    微服务基本只有 request/response 的模式。做不了 streaming?微服务通常要求应用是无状态的才能做到水平扩展。streaming 本身就是加入了状态
    的头像 发表于 12-29 11:18 215次阅读

    如何搭建微服务架构的全局图景

    如果一直保持共用数据库的模式,则整个架构会越来越僵化,失去了微服务架构的意义。因此小明和小红一鼓作气,把数据库也拆分了。所有持久化层相互隔离,由各个服务自己负责。另外,为了提高系统的实
    的头像 发表于 12-27 15:16 248次阅读
    如何搭建<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>的全局图景

    如何构建弹性、高可用的微服务

    基于微服务的应用程序可实现战略性数字转型和云迁移计划,对于开发团队来说,这种架构十分重要。那么,如何来构建弹性、高可用的微服务呢?RedisEnterprise给出了一个完美的方案
    的头像 发表于 11-26 08:06 238次阅读
    如何构建弹性、高可用的<b class='flag-5'>微服务</b>?

    docker微服务架构实战

    的容器化技术,为微服务架构的实施提供了强大的支持。本文将介绍Docker微服务架构的实战经验,包括Docker的概述、微服务
    的头像 发表于 11-23 09:26 315次阅读

    springcloud微服务架构

    Spring Cloud是一个开源的微服务架构框架,它提供了一系列工具和组件,用于构建和管理分布式系统中的微服务。它基于Spring框架,旨在通过简化开发过程和降低系统复杂性来帮助开发人员构建弹性
    的头像 发表于 11-23 09:24 390次阅读

    深入探讨微服务和事件驱动架构区别

    微服务不同,事件驱动架构不要求强制的粒度。事件处理器可以有不同的规模,可以是响应特定事件的小型功能,也可以是处理多个事件的大型子系统。在物流系统中,事件驱动架构可以包括用于包裹跟踪更新的小型事件处理器,也可以有更大的子系统用于
    的头像 发表于 10-30 15:06 262次阅读

    Spring Cloud :打造可扩展的微服务网关

    Spring Cloud Gateway是一个基于Spring Framework 5和Project Reactor的反应式编程模型的微服务网关。它提供了丰富的功能,包括动态路由、请求限流、集成安全性等,使其成为构建微服务架构
    的头像 发表于 10-22 10:03 260次阅读
    Spring Cloud :打造可扩展的<b class='flag-5'>微服务</b>网关

    SpringCloud微服务架构:实现分布式系统的无缝协作

    在深入Spring Cloud之前,让我们首先了解一下什么是微服务架构微服务架构是一种软件架构模式,将一个应用程序拆分为一组小型、独立的
    的头像 发表于 10-12 16:21 265次阅读
    SpringCloud<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>:实现分布式系统的无缝协作

    边缘计算微服务操作系统的设计与实现

    面对边缘计算运行环境不统一、适配难,工业边缘计算微服务开发难度高,微服务生态系统碎片化,以及工业边缘计算行业应用难以落地等技术和行业共性问题,本文实现了一种边缘计算微服务操作系统,包括边缘计算
    的头像 发表于 08-31 16:49 611次阅读
    边缘计算<b class='flag-5'>微服务</b>操作系统的设计与实现

    【Spring Cloud 】基于微服务架构的智慧工地监管平台源码带APP

    技术架构微服务 开发语言:Java 开发工具:Idea 前端框架:Vue 后端框架:Spring Cloud 数 据 库:MySql 移 动 端:UniApp
    的头像 发表于 08-28 11:10 376次阅读
    【Spring Cloud 】基于<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>的智慧工地监管平台源码带APP

    润和软件HopeStage操作系统与联奕科技微服务架构统一权限管理软件完成产品兼容性互认证

    近日,润和软件HopeStage 操作系统与联奕科技股份有限公司微服务架构统一权限管理软件完成产品兼容性测试。
    的头像 发表于 06-26 15:22 611次阅读

    释放微服务架构全部潜力的关键

      释放微服务的力量 您是否正在努力构建高效、可扩展且有弹性的软件系统?作为软件开发人员或高级开发人员,您一定遇到过“微服务架构”一词。这种革命性的软件开发方法已被许多成功的科技巨头采用,例如
    的头像 发表于 06-25 11:54 333次阅读
    释放<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>全部潜力的关键

    微服务架构中的数据一致性解决方案与实践

    作为互联网公司的研发工程师,微服务架构思想对于各位读者朋友来说,已经不是陌生东西。我们当中的大多数人,或多或少经历过从单体应用到微服务化的系统拆分和演进过程。我们按照庞大系统的业务功能和特征,将其
    的头像 发表于 06-14 10:20 283次阅读
    <b class='flag-5'>微服务</b><b class='flag-5'>架构</b>中的数据一致性解决方案与实践

    从分层架构微服务架构介绍(五)

    本文要介绍的是 服务架构 (Service-Based Architecture, SBA )。 SBA 可以看成是单体架构微服务架构
    的头像 发表于 05-10 17:02 595次阅读
    从分层<b class='flag-5'>架构</b>到<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>介绍(五)