热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

组织的沟通和系统的设计

架构师进阶,微服务设计与治理的16条常用原则 上一篇文章我们从「存储选型」角度学习了架构师的基本能力。今天将从存储的上一层「服务维度」学习架构师的第二项常用能力——微服务设

架构师进阶,微服务设计与治理的16条常用原则

 

上一篇文章我们从「存储选型」角度学习了架构师的基本能力。

今天将从存储的上一层「服务维度」学习架构师的第二项常用能力——微服务设计与治理。



  • 如何设计合理的微服务架构?

  • 如何保持微服务健康运行?

这是我们对微服务进行架构设计过程中非常关注的两个问题。

本文对微服务的生命周期定义了七个阶段,如下图所示。

架构师进阶,微服务设计与治理的16条常用原则

 

围绕这七个阶段总结了16条常用原则。


1、微服务规划

原则1: 按照业务能力(business capabilities)来规划或拆微服务。

康威定律:Conway’s law: Organizations which design systems[…] are constrained to produce designs which are copies of the communication structures of these organizations.
(设计系统的组织,其产生的设计和架构等价于组织间的沟通结构。)

组织的沟通和系统的设计之间紧密相连,特别是复杂系统,解决好人与人的沟通才能有一个更好的系统设计。

《人月神话》中总结出了随着人员的增加沟通成本呈指数增长的规律:沟通成本 = n(n-1)/2。举例说明:



  • 5人项目组,需要沟通的渠道是 5*(5–1)/2 = 10

  • 15人项目组,需要沟通的渠道是15*(15–1)/2 = 105

  • 50人项目组,需要沟通的渠道是50*(50–1)/2 = 1,225

系统越复杂,人手越多,沟通成本也呈指数增长。因此,分而治之便是大多数公司选择的解决方案。分不同的层级,分不同的小团队,让团队内部完成自治理。


原则2: 按照领域驱动设计(Domain-Driven Design,DDD)来规划或拆解微服务。

领域驱动设计是微服务领域的热门话题,本文不展开说明,仅说明几点重要事项:



  • 基本过程:抽象业务、分析流程、识别边界、建立模型、映射到服务和代码

  • 避免过度耦合、存在贫血领域对象等情况

  • 划分界限上下文,厘清上下文之间的映射关系,比如合作关系、共享内核、客户方-供应方开发、防腐层、开放主机服务等等。

  • 细化上下文对象,区分实体、值对象、聚合根、领域服务、领域事件


原则2与原则1的区别在于,原则1关注组织架构领域,原则2更偏向软件工程设计领域。



2、微服务设计

原则3:微服务的设计应该遵循「单一职责」原则

所谓单一职责原则,就是对一个服务而言,它的功能要单一,只做与它相关的事情。

在微服务的设计过程中要按职责进行设计,彼此保持正交,互不干涉。

什么样的单一领域对象的单一职责微服务才是有价值的?就是不断有业务变化,能够维持业务持久性,有业务生命力的领域对象。举例来说:



  • 与别的功能点相比,调用频率非常高

  • 或者其数据量存量大,数据增速快,TB级甚至是PB级的。

那么就很有价值独立为一个微服务,实现独立演进、个性化的弹性伸缩。

所以,我们在进行微服务设计时,要能够分析、预测出需求变化的点在哪里?高并发的点在哪些?数据增长的位置在哪里?与DDD分析相结合,找出最有价值的那个单一职责,进行合理、适度的领域、子领域、有界上下文分解,才能更好的应对复杂的业务、不断变化的业务。


原则4: 微服务的设计应该遵循「高内聚」原则

过度追求「单一职责」,或者拆分微服务过细,往往会带来不良后果。微服务的设计并不是越细越好,过度拆分会导致调用性能变差、数据一致性难以保障、系统可用性降低等问题。

因此,「高内聚」原则要求:



  • 完全独立。微服务粒度的下界是它至少应满足独立,能够独立发布、独立部署、独立运行与独立测试

  • 足够内聚。强相关的功能与数据在同一个服务中处理

  • 足够完备。一个服务包含至少一项业务实体与对应的完整操作


原则5:微服务的设计应该遵循「低耦合」原则

  • 避免数据过度暴露

  • 避免数据库共享

  • 最小化同步调用,如有必要,引入事件驱动进行异步调用


3、微服务实现

原则6:服务无状态。

什么是「状态」?如果一个数据需要被多个服务共享,才能完成一笔交易,那么这个数据被称为状态。

依赖这个「状态」数据的服务被称为有状态服务,反之称为无状态服务。

「无状态」原则并不是说在微服务架构里就不允许存在状态,而是要把有状态的业务服务改变为无状态的计算类服务,那么状态数据也就相应的迁移到对应的“有状态数据服务”中。

架构师进阶,微服务设计与治理的16条常用原则

 

场景说明:例如我们以前在本地内存中建立的数据缓存、Session缓存,到现在的微服务架构中就应该把这些数据迁移到分布式缓存中存储,让业务服务变成一个无状态的计算节点。迁移后,就可以做到按需动态伸缩,微服务应用在运行时动态增删节点,就不再需要考虑缓存数据如何同步的问题。

只有服务无状态,才能实现快速弹性扩缩容,应对流量峰谷。


原则7:服务高可用。

接入高可用中间件(如sentinal),实现限流、熔断、降级,增强可用性


原则8:服务可观测。

除了默认系统监控外,微服务需要梳理并定义必要的「业务监控指标」。


原则9:服务配置可管理。

微服务相关配置需要统一接入配置中心进行管理、控制。


4、微服务调用

原则10:避免「分布式大单体」

只做单向调用,避免循环调用。
多个服务循环依赖调用形成集中式“分布式大单体”,违背微服务的原则。


原则11:异步解耦。

按需接入消息队列,实现「依赖解耦」、「流量削峰」



  • 串行同步调用异步化,提高响应能力和响应速度

  • 应对突发流量,实现流量削峰与流量控制

  • 解耦核心业务逻辑不必要的依赖

  • 业务设计中的最终一致性


原则12:引入BFF层,降低客户端与后端微服务之间的耦合

尽量设计BFF层,把前端的特殊需求交给BFF层,使后端服务逻辑具有高内聚、高复用性的精简核心逻辑。


5、微服务发布

原则13:服务发布遵循安全发布三板斧

保证「可灰度」、「可监控」、「可回滚」。


6、微服务治理

原则14:正视「架构腐化」,遵循「持续演进」原则

「架构腐化」的常见场景:



  • 多人维护一个微服务,出现「频繁代码冲突」,影响快速迭代,那么这个微服务就需要拆分了。

  • 当你修改了一个边角的小功能,但是你不敢马上上线,因为你依赖的其他模块才开发了一半,出现大量「功能耦合」,那么这个微服务就需要拆分了。

  • 当你发现微服务A内聚合a的功能变成了海量高频业务。这时聚合a就会拖累整个微服务A,并且因为聚合a面临性能瓶颈,在微服务A进行弹性扩缩时,也会造成资源浪费。这时,我们就可以将聚合a从微服务A中整体拆分,独立为一个新微服务B。在资源配置方面也可以更加有针对性的投入到微服务B,可以随时满足高频访问的性能要求了。

  • 当你发现在领域建模时错误地将聚合d放到了微服务C里,或者随着业务发展聚合d更适合放在微服务D里。由于领域模型的不合适,可能会导致微服务之间出现频繁调用,进而导致微服务之间出现「紧耦合关系」。这时,我们就可以对领域模型做出调整,将聚合d从微服务C整体迁移到微服务D里。


原则15:参考「AKF扩展立方」模型,服务除了「水平扩容」外,还可以考虑「功能拆分」或者 「数据分区」

架构师进阶,微服务设计与治理的16条常用原则

 



  • X轴:服务和数据的水平扩容。

  • Y轴:功能/业务拆分

  • Z轴:沿客户边界的服务和数据分区

「水平扩容」比较容易理解,直白点说就是加机器。根据AKF模型,除了加机器外,我们还可以考虑「功能拆分」或者 「数据分区」。

「功能拆分」相对复杂,一般包括几种模式:



  • 微服务拆分。根据具体业务模型、领域模型拆分更细粒度的微服务。

  • 业务隔离拆分。利用消息队列,将在线业务(OLTP)和耗费大量资源的计算任务拆分隔离。

  • 核心与非核心隔离。对于一个微服务,可以将SKA客户与普通客户进行隔离,SKA客户使用独立的集群资源,提高稳定性。

「数据分区」往往指的是数据库层面。需要引入数据库中间件,像 sharding-jdbc、mycat 等,在数据层面需要配置相应的分片逻辑。正确的拆分对提高系统的容量有很大的帮助,失败的拆分可能会造成热点集中,得不偿失。常用的分区逻辑包括 按照时间分区、按照用户id取模分区等。


7、微服务下线

原则16:对于「废弃服务」,需要做好「下线」工作,包括服务下线、存储释放等。

清理无效代码、环境,减少维护成本。同时释放资源,节约成本。


8、总结

架构师在进行微服务设计和微服务治理时,可以围绕微服务生命周期的七个阶段展开。

本文总结了16条常用原则,希望能提供一些思路和启发。

如果你有其他补充和建议,欢迎留言讨论。

作者:Leo_wl

    出处:http://www.cnblogs.com/Leo_wl/

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

版权信息



推荐阅读
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 使用Docker安装和运行Nexus
    本文介绍了使用Docker安装和运行Nexus的方法,包括docker-compose.yml配置和启动时可能出现的权限问题解决方法。同时提供了登录控制台验证安装的地址和登录信息。 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • “您可以从三个选项中(快速、便宜或好)选择两个”提出这个问题的人可能不是可观测性工程师。但也可能是,在可观测性方面,决定您 ... [详细]
  • 熟练掌握Spring Cloud,终于成为Java工程师的面试门槛 ... [详细]
  • [翻译]微服务设计模式5. 服务发现服务端服务发现
    服务之间需要互相调用,在单体架构中,服务之间的互相调用直接通过编程语言层面的方法调用就搞定了。在传统的分布式应用的部署中,服务地 ... [详细]
  • 服务网关与流量网关
    一、为什么需要服务网关1、什么是服务网关传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务,如果没有网关& ... [详细]
  • DockerDataCenter系列(四)-离线安装UCP和DTR,Go语言社区,Golang程序员人脉社 ... [详细]
  • 有意向可以发简历到邮箱内推.简历直达组内Leader.能做同事的话,内推奖励全给你. ... [详细]
  • BPM是什么软件?1、BPM是BusinessProcessManagement的简称,译为业务流程管理,它是一种以规范化的构造端到端的卓越业务流程为中心以持续的提高组织业务绩效为 ... [详细]
  • TiDB | TiDB在5A级物流企业核心系统的应用与实践
    TiDB在5A级物流企业核心系统的应用与实践前言一、业务背景科捷物流概况神州金库简介二、现状与挑战神州金库现有技术体系业务挑战应对方案三、TiDB解决方案测试迁移收益问题四、说在最 ... [详细]
  • 【MicroServices】【Arduino】装修甲醛检测,ArduinoDart甲醛、PM2.5、温湿度、光照传感器等,数据记录于SD卡,Python数据显示,UI5前台,微服务后台……
    这篇文章介绍了一个基于Arduino的装修甲醛检测项目,使用了ArduinoDart甲醛、PM2.5、温湿度、光照传感器等硬件,并将数据记录于SD卡,使用Python进行数据显示,使用UI5进行前台设计,使用微服务进行后台开发。该项目还在不断更新中,有兴趣的可以关注作者的博客和GitHub。 ... [详细]
  • zuul 路由不生效_Zuul网关到底有何牛逼之处?竟然这么多人在用~
    作者:kosamino来源:cnblogs.comjing99p11696192.html哈喽,各位新来的小伙伴们,大家好& ... [详细]
author-avatar
pierce2502910693
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有