当前位置:首页 > 科技  > 软件

DDD 必备架构--六边形架构

来源: 责编: 时间:2023-08-09 23:04:00 211观看
导读架构是研究“分”和“合”的艺术,通过“分离关注点”将系统拆分为多个部分,然后在“原则和规则”的约束下对组件进行装配,形成高内聚的构件;再根据需求对多个构件进行关联,形成低耦合的连接,最终构建“高内聚低耦合”的软件

架构是研究“分”和“合”的艺术,通过“分离关注点”将系统拆分为多个部分,然后在“原则和规则”的约束下对组件进行装配,形成高内聚的构件;再根据需求对多个构件进行关联,形成低耦合的连接,最终构建“高内聚低耦合”的软件系统。1Z028资讯网——每日最新资讯28at.com

图片图片1Z028资讯网——每日最新资讯28at.com

为了有效应对软件复杂性,通常会对其进行分类,然后对症下药逐个击破。1Z028资讯网——每日最新资讯28at.com

1. 软件系统复杂性

面对一个软件需求,我们经常会将其分为两类:1Z028资讯网——每日最新资讯28at.com

  1. 功能性需求。就是产品提出的众多业务功能,例如:用户登录、查询数据、添加订单等;
  2. 非功能性需求。指系统在实现功能时必须满足的技术指标,最常见的包括性能、可靠性、安全性、可维护性、易用性等,例如:系统的响应时间、并发访问量、容错能力、数据安全性、可扩展性等。

其实,这两类需求整好与软件系统的两类“复杂性”一一对应:1Z028资讯网——每日最新资讯28at.com

  1. 业务复杂性,指系统中业务逻辑和业务规则的复杂程度。业务复杂性主要来自于业务的规模、结构、变化性等,这个与软件所在领域有极大关系;
  2. 技术复杂性,指系统中所用技术的复杂程度。技术复杂性主要来自于所使用的数据库、网络协议、中间件、应用框架等,这与软件架构和基础设施关系巨大;

面对不同的需求和复杂性,其设计目标和应对方式也完全不同。1Z028资讯网——每日最新资讯28at.com

1.1. 业务复杂性

首先,看下业务复杂性:1Z028资讯网——每日最新资讯28at.com

图片图片1Z028资讯网——每日最新资讯28at.com

对于业务需求,我们追求的是系统的复用性和扩展性。1Z028资讯网——每日最新资讯28at.com

  • 复用性。指组件或模块能够在不同的场景下被重复使用。高复用性设计能够大幅度减少开发和维护的成本,提高开发效率。组件的粒度越小复用性越高,功能结构越清晰,逻辑调整越便利,与之相反的是代码重复率,重复代码是系统腐化的重要标志;
  • 扩展性。能够在不改变现有系统结构的情况下,方便地添加新的功能或修改现有功能。具有高扩展性的系统能够满足未来需求的变化,降低系统的维护成本。

导致业务代码变化的原因有很多,比如:1Z028资讯网——每日最新资讯28at.com

  • 线上bug。线上bug很少但对业务系统的伤害巨大,发现bug后为了快速修复问题,往往选择短平快的方式而非最佳方案,这些“补丁”就像系统中的“飞线”在代码中穿梭,成为超出三界的定时炸弹,一不小心就会给你意外的“惊喜”;
  • 新功能需求。这是代码膨胀的主要推动力,开发人员将产品提出的需求翻译成代码,不停的“塞入”到代码仓库,导致仓库快速膨胀,很快你将面对几十万行代码并在之上进行新的开发;
  • 创新性业务。意味着新建系统、新建仓库、新建服务,看起来一切非常良好,可以一次性甩掉多年的历史包袱,但公司整个系统变得越来越复杂,甚至没人能说出服务间的调用关系;

这些变更都会导致业务代码越来越多、逻辑越来越复杂,最终变得难以维护。1Z028资讯网——每日最新资讯28at.com

为了更好的应对这些变化,常见的手段包括:1Z028资讯网——每日最新资讯28at.com

  • DDD, 构建于“领域模型”基础之上,使用面向对象的各种语言特性,实现逻辑的封装、复用;将业务概念和实现组件结合在一起,避免相互转化,从而降低沟通成本;
  • 重构,随着业务的变化,对原有代码结构进行优化,在新结构上以扩展的方式完成新功能的添加,不断地对代码结构进行调优
  • TDD,重构的重要保障,在优化代码结构的同时,保障不会破坏原有的业务逻辑

业务复杂性先简单介绍到这,接下来看下技术复杂性:1Z028资讯网——每日最新资讯28at.com

1.2. 技术复杂性

图片图片1Z028资讯网——每日最新资讯28at.com

对于非功能需求,我们追求的是系统的高性能和高可用。1Z028资讯网——每日最新资讯28at.com

  • 高性能。在同等资源下,要么让系统运行尽可能快,要么让系统吞吐尽可能大
  • 高可用。尽量保障系统 7 * 24h 不间断的提供服务,避免由于服务中断导致公司损失

导致技术复杂性激增的原因有很多,比如:1Z028资讯网——每日最新资讯28at.com

  • 用户和并发量。随着用户和并发量的激增,系统承受的压力将越来越大,一个小小的卡点便能造成巨大的损失
  • 系统数据量。随着系统数据量不断积累,当单表数据量超过 亿 级,不管是访问速度还是异常恢复都将面临巨大挑战
  • 机器规模。当机器规模超过一定的阈值,硬件问题将频繁爆发,基本每天都会出现硬件故障,最终成为高可用的阻力

这些问题并不能通过简单的增加代码来解决,往往需要引入新技术或使用新方案:1Z028资讯网——每日最新资讯28at.com

  • 新技术。当数据库表数据量达到“亿”级出现明显的性能瓶颈时,可以应用 分库分表 或 TiDB 来解决
  • 新方案。当数据库读压力巨大,可以调整技术方案,使用数据库读写分离、增加缓存等方案解决

通过对比,是否有一种感觉:“业务”与“技术” 差距巨大,可以说是天壤之别。所以需要一种架构,能够对 “业务” 和 “技术” 进行隔离,降低两者的相互影响,使得:1Z028资讯网——每日最新资讯28at.com

  • 技术调整不影响业务模型
  • 业务调整不能依赖技术

六边形架构,便可以解决这个问题。1Z028资讯网——每日最新资讯28at.com

2. 六边形架构

六边形架构出自《实现领域驱动设计》一书,与“洋葱架构” 非常相似,都能很好的实现 “业务” 与 “技术” 的分离。1Z028资讯网——每日最新资讯28at.com

在 “Command侧”(详见CQRS架构) DDD 仍旧是最佳解决方案,所以在此使用 “六边形架构” 作为顶级架构。1Z028资讯网——每日最新资讯28at.com

六边形架构如下:1Z028资讯网——每日最新资讯28at.com

图片图片1Z028资讯网——每日最新资讯28at.com

该架构由内外两个六边形组成,这也是其名称来源:1Z028资讯网——每日最新资讯28at.com

  • 内六边形属于业务域,用于应对业务复杂性。
  • 外六边形属于技术域,用于应对技术复杂性。
  • 其中内六边形是整个系统的核心,外六边形依赖于内六边形,而内六边形不依赖于外六边形
  • 内外两个六边形存在清晰的边界,两者相互独立,互不影响,独自演进

2.1.【业务】内六边形

内六边形聚焦于业务逻辑,使用良好的设计应对业务的复杂性;通过提升系统的复用性和扩展性,来应对未来的变化。1Z028资讯网——每日最新资讯28at.com

2.1.1. DDD

DDD 是解决复杂业务的一把利器,将业务需求和代码实现相结合,通过对业务领域的深入理解,构建出可复用、可维护、可扩展的领域模型。1Z028资讯网——每日最新资讯28at.com

DDD 分为战略和战术两部分,在此重点阐述战术部分。战术模型主要包括:1Z028资讯网——每日最新资讯28at.com

  • 实体(Entity):具有唯一标识的领域对象,具有丰富的属性和行为,表示需要持续跟踪的领域概念,比如 用户、订单、地址等;
  • 值对象(Value Object):没有唯一标识的领域对象,具有属性和行为,一般用于表示某一个领域概念,比如 金额、邮箱、手机号等;
  • 聚合根(Aggregate Root):一组由实体和值对象组成的高内聚对象集合,由一个根实体来管理它们,我们也称之为聚合根,比如 订单+订单项便组成了一个聚合,其中订单为聚合根;
  • 工厂(Factory):创建领域对象的一种机制,也是设计模式在 DDD 中的落地,它隐藏了对象创建细节,并保障创建对象的有效性,主要解决复杂对象初始化问题;
  • 存储库(Repository):提供对领域对象的持久化和检索功能,将领域对象从数据存储细节中分离出来,完成领域对象和存储引擎的解耦;
  • 领域服务(Service):处理领域对象之间的交互,没有自己的状态,封装了一些业务逻辑,主要用于需要多个领域对象相互协作才能完成的业务场景,比如银行转账;
  • 领域事件(Event):指在领域内发生的、有意义的、需要被捕捉的事件,主要完成服务内的流程解耦和服务间的系统解耦;

这些领域对象相互协作,共同承载复杂的业务场景,大幅提升了业务的复用性和扩展性。1Z028资讯网——每日最新资讯28at.com

2.1.2. TDD

也称为测试驱动开发,它的基本思想是在编写代码之前先编写测试,然后根据测试来编写代码,最后再运行测试。可以帮助开发人员更快地发现并修复代码中的bug,还可以让开发人员更加关注代码的设计,使代码更加健壮、可扩展和易维护。1Z028资讯网——每日最新资讯28at.com

业务模型与基础设施的解耦将为你的 TDD 带来众多好处:1Z028资讯网——每日最新资讯28at.com

  • 提高测试的速度:使用 Mock 技术可以避免测试过程中涉及到缓慢的网络或数据库操作,从而提高测试速度,加快迭代周期;
  • 提高测试可靠性:使用 Mock数据可以降低测试失败或不可靠的情况,避免由于数据变更所造成的测试不稳定问题;
  • 更好的测试隔离:业务逻辑和基础设施可以并行开发,避免两者相互干扰而产生不确定行为;
  • 有利于重构:业务逻辑和外部依赖分离,在重构代码时,可以聚焦于业务逻辑而不必担心外部依赖的稳定性和正确性;
2.1.3. 两顶帽子

两顶帽子,是落地重构的重要开发模式,是一种工作习惯,或者说是一种高效的工作流程。1Z028资讯网——每日最新资讯28at.com

两顶帽子法,将软件变更落地过程分为两个阶段:1Z028资讯网——每日最新资讯28at.com

  • 优化结构阶段。在不改变软件行为的前提下,对软件结构进行优化,使其更具扩展性。比如:
  1. 【重构】抽取公共逻辑到方法、类,以便更好的被复用;
  2. 【设计模式】抽取模板方法,对核心逻辑进行统一;
  3. 【架构模式】抽取功能微内核,确定插件签名和功能;
  • 添加功能阶段。在调整后的具备更好的扩展性的代码基础上完成功能调整或者增加新功能,如:
  • 新功能复用已有组件能力,避免重复开发;
  • 以扩展点的方式增加新功能,提升开发效率;

2.2.【技术】外六边形

外六边形聚焦于技术,与公司基础设施密切相关,也受所用框架的各种约束。其核心是发挥框架和中间件的优势,更好的为业务提供服务。1Z028资讯网——每日最新资讯28at.com

根据应用场景的不同,我们将外六边形的组件分成两类:1Z028资讯网——每日最新资讯28at.com

  • 输入适配器。将来自外部的数据转换为系统可以使用的格式;
  • 输出适配器。将系统内部的数据转换为外部可以使用的格式

他们是系统与外部的“翻译官”,将外部请求转换为系统可以理解的指令,并将系统响应转换为外部世界可以理解的格式,这种松耦合可以使系统更加灵活更具扩展性。1Z028资讯网——每日最新资讯28at.com

2.2.1. 输入适配器

负责将外部系统的请求转换为应用服务能够处理的格式,通常包括Web 请求、RPC调用、消息队列、定时任务等,是将外部请求转换为内部指令的桥梁。1Z028资讯网——每日最新资讯28at.com

常见的输入适配器主要包括:1Z028资讯网——每日最新资讯28at.com

  • Web 请求。处理 HTTP 请求,对请求进行转换、验证,将其转换为应用服务所需格式,调用接口完成业务逻辑,最后将处理结果转化为所需格式进行返回。常见的框架有 Spring MVC、Struct2等;
  • RPC 调用。处理远程调用请求,将请求转换为应用程序所需格式,调用应用服务接口完成业务逻辑,最后返回处理结果;在 Spring Cloud 技术栈下,与 Web 请求高度类似,但仍旧具有自己的特点,需要与 Web 请求进行区分处理。常见的 RPC 框架有 Spring Cloud、gRPC、Thrift、Dubbo等;
  • 消息队列。主要指的是消息队列的消费端,从消息队列中读取消息,将信息转换为应用程序所需格式,调用应用服务接口完成业务逻辑。常见的有 RocketMQ、Kafka、RabbitMQ等;
  • 定时任务。由定时器周期性触发,调用应用服务的业务方法,完成某种后台任务。常见的有Quartz、XXL-job、Spring Task 等;
2.2.2. 输出适配器

负责将应用程序输出结果转换为外部系统能够理解的格式,通常包括数据库、RPC调用、缓存、搜索、消息队列、文件系统等,是将内部响应转换为外部响应的桥梁。1Z028资讯网——每日最新资讯28at.com

常见的输出适配器主要包括:1Z028资讯网——每日最新资讯28at.com

  • 数据库。将领域模型中的模型数据保存到数据库进行持久化存储,常用的框架包括 MyBatis、Jpa、Hibernate等,中间件主要是 MySQL;
  • 缓存。模型数据发生变更后,对缓存数据进行清理或更新,常见框架包括本地缓存 Guava、Caffeine、EhCache,分布式缓存有 Redis、Memcache、Tair等;
  • 搜索。为应对多维度查询,系统会引入搜索引擎组件,在模型数据发生变更后,需要将变更同步到搜索引擎,常见的有Elasticsearch、Solr、Sphinx等;
  • 消息队列。这里主要指的是消息队列的发送端,当业务操作完成后,系统会向外发布领域事件,以将变更通知到下游系统,常见的有 RocketMQ、Kafka、RabbitMQ等;
  • RPC调用。这里主要指的是 RPC 的调用端,当业务模型对其他领域服务存在依赖时,需要通过 RPC 进行系统通信,常见的 RPC 框架有 Spring Cloud、gRPC、Thrift、Dubbo等;
  • 文件系统。这里简单理解为系统的日志输出即可,常见的有Log4j、Logback、SLF4J、JUL等;

这么多纷繁复杂的框架、中间件从另一个层面也验证了,外六边形是以技术作为驱动的,其核心就是:如何更好的使用这些技术工具,发挥每个框架的强项。1Z028资讯网——每日最新资讯28at.com

3. 小结

任意一个业务系统都会面对两类需求:1Z028资讯网——每日最新资讯28at.com

  • 来自业务的功能性需求;
  • 来自技术的非功能性需求;

两类需求背后的驱动力(复杂性)完全不同:1Z028资讯网——每日最新资讯28at.com

  • 功能性需求的驱动力在于业务自身的复杂性和多变性;
  • 非功能性需求的驱动力在于架构的变更和技术的更迭;

为了更好的应对这两类变化,需要在架构上进行隔离,避免相互影响带来更多的复杂性,然后逐个击破。这就是六边形架构最擅长的领域:1Z028资讯网——每日最新资讯28at.com

  • 内六边形。聚焦于业务解决功能性需求,常用的手段有 DDD、TDD、重构;
  • 外六边形。聚焦于技术解决非功能性需求,需要使用好 输入适配器 和 输出适配器;

本文链接:http://www.28at.com/showinfo-26-5202-0.htmlDDD 必备架构--六边形架构

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 三言两语说透设计模式的艺术-抽象工厂模式

下一篇: 浅析数据工程

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 一加首款折叠屏!一加Open渲染图出炉:罕见单手可握小尺寸

    一加首款折叠屏!一加Open渲染图出炉:罕见单手可握小尺寸

    8月5日消息,此前就有爆料称,一加首款折叠屏手机将会在第三季度上市,如今随着时间临近,新机的各种消息也开始浮出水面。据悉,这款新机将会被命名为“On
  • 一年经验在二线城市面试后端的经验分享

    一年经验在二线城市面试后端的经验分享

    忠告这篇文章只适合2年内工作经验、甚至没有工作经验的朋友阅读。如果你是2年以上工作经验,请果断划走,对你没啥帮助~主人公这篇文章内容来自 「升职加薪」星球星友 的投稿,坐
  • 三言两语说透设计模式的艺术-单例模式

    三言两语说透设计模式的艺术-单例模式

    写在前面单例模式是一种常用的软件设计模式,它所创建的对象只有一个实例,且该实例易于被外界访问。单例对象由于只有一个实例,所以它可以方便地被系统中的其他对象共享,从而减少
  • 共享单车的故事讲到哪了?

    共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    按照惯例,苹果将继续在今年9月举办一年一度的秋季新品发布会,有传言称发布会将于9月12日举行,届时全新的iPhone 15系列将正式与大家见面,不出意外的话
  • OPPO K11采用全方位护眼屏:三大护眼能力减轻视觉疲劳

    OPPO K11采用全方位护眼屏:三大护眼能力减轻视觉疲劳

    日前OPPO官方宣布,全新的OPPO K11将于7月25日正式发布,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼IMX890主摄,堪称是2000档位影像表
  • 机构称Q2全球智能手机出货量同比下滑11% 苹果份额依旧第2

    机构称Q2全球智能手机出货量同比下滑11% 苹果份额依旧第2

    7月20日消息,据外媒报道,研究机构的报告显示,由于需求下滑,今年二季度全球智能手机的出货量,同比下滑了11%,三星、苹果等主要厂商的销量,较去年同期均有下
Top