DDD理论学习系列(2)-- 领域

DDD理论学习系列目录微信

1. 引言

领域一词,主要有如下两个意思:学习

  1. 一国主权所达之地。
  2. 学术思想或社会活动的范围。

不论是指国家的主权范围也好仍是学术活动范围,都是在讲一个范围,一个界限。
好比咱们常说的,学术领域、思想领域、技术领域、语言领域、物理领域、医学领域、游戏领域、JAVA领域、.NET领域等等,它们中不论是泛指仍是特指某个领域,都是限定在某个范围以内的。
因而可知领域一词重在范围的界限网站

下面咱们就回归正传,DDD,Domain Drive Design,全称,领域驱动设计。那这个领域具体指什么呢,在DDD中有什么特殊含义呢?设计

2. DDD中的领域

咱们要先弄明白DDD是干什么的。
DDD是一种综合软件系统分析和设计的面向对象建模方法,旨在帮咱们设计高质量的软件模型,是一种解决复杂中大型软件的一套行之有效的方式。日志

那既然是用来解决软件问题,那天然要弄清楚软件系统的业务需求。对象

那就以咱们以前的办公设备微信公众号开发的案例为例,来分析一下。
虽然是微信公众号开发,但其实涉及到的主要是商品、用户、订单、报价、支付、物流、报修相关业务,其本质仍是电子商务系统开发。
反过来看,任何电子商务网站也都涉及到商品、用户、订单、支付、物流这些核心业务,而这也正是全部电商领域都会涉及到的业务。游戏

其实不论是普通的电子商务网站,仍是像京东、淘宝、亚马逊这样的电商平台,其本质都是电商领域,只不过是系统的复杂性不一样而已。开发

因此咱们的案例也就能够理解为一个基于微信公众号平台的电商领域普通电子商务网站的开发。get

经过以上的举例说明,只是想说明,DDD中的领域也并无什么特别之处,它只是被界限在指定的业务需求之中,有了更清楚的范围边界。电商

其实也能够参照原著《领域驱动设计:软件核心复杂性应对之道》的总结:

一个领域本质上能够理解为就是一个问题域,只要是同一个领域,那问题域就相同。因此,只要咱们肯定了系统所属的领域,那这个系统的核心业务,即要解决的关键问题、问题的范围边界就基本肯定了。

弄清了业务领域,接下来就是领域的拆分。下面咱们就来细化咱们案例中的业务场景,来介绍引入的核心域和子域的概念。

3. 子域

回到咱们的案例,基于微信公众号的电子商务网站的开发。
咱们先抛开DDD,按照咱们传统的开发设计思路,以数据优先的方式,上来就建表写代码,并且按照咱们一向的做风,确定会先设计Product表,由于电商的哪个环节都跟商品息息相关,在这里Product对象就是一个核心对象。
那既然Product对象是核心对象,那Product对象所处的领域--商品列表领域,是否是就是咱们这一节讲的核心域?
答案是否认的。
DDD跟咱们传统的软件开发设计过程不一样,它注重领域建模。
在了解了业务领域的业务规则以后,咱们为了完成对一个复杂领域的分析,每每咱们要先简化之,即领域拆分。能够理解为把领域中的复杂大问题,拆分红小问题,各个击破。也就是将一个领域拆分红多个子域,再针对每一个子域进行分析。而子域又能够分为核心域、通用子域、支撑子域。
那什么是核心域、通用子域、支撑子域呢?
下面咱们就对咱们的案例进行拆分来梳理这些概念。

对于咱们的案例涉及到的业务,商品、用户、订单、报价、支付、物流、报修相关业务,咱们能够大体拆分红如下几个子域:

  • 商品子域
  • 用户子域
  • 销售子域
  • 订单子域
  • 支付子域
  • 物流子域
  • 维修子域

3.1 核心域

若是从几个子域中肯定核心域,这也许难以决定,不要紧。咱们先来回答一个问题。
什么是电商网站?在线商品买卖平台。
电商领域的核心就是为了商品买卖
咱们知道开发这个电商网站的目的是为了寻求推广和销售利润的最大化。
因此天然而然核心域就是销售子域了。

为何要先肯定核心域?
由于做为一个业务的核心存在,它最能体现系统的核心价值,也是核心竞争力。若是要最大化系统的价值,咱们必然要在核心域的设计上更胜一筹。
肯定核心域后,咱们在进行开发设计的时候就有了主次之分。

3.2 通用子域

通用子域,顾名思义,也就是服务于整个业务领域。好比咱们要为该网站提供一个日志系统,用来记录一些日志。咱们能够设计一个日志子域来供其余子域使用。

3.3 支撑子域

支撑子域的做用于业务系统的某些重要业务而非核心业务,它关注于业务的某一方面,来支撑完善业务系统。
咱们划分的子域中除了销售子域,其余均可以说是支撑子域。
好比物流子域,就是专一于物流相关业务,支撑着订单发货以及物流跟踪的重要流程。

4. 总结

本节主要结合案例,简要梳理了DDD中领域、核心域、通用子域、支撑子域的定义。

  • 领域是有范围界限的,也能够说是有边界的。
  • 核心域是业务系统的核心价值所在,承载着一个系统的重中之重。
  • 通用子域能够理解为业务系统全部子域的消费者,提供着通用服务。
  • 支撑子域专一于业务系统的某一重要的业务,来支撑和完善业务系统。

这一节遗留了一个问题,那就是文章开头就说领域是有范围界限的,但这个范围界限在DDD中如何表述呢? 这就是下一篇文章要讲的——限界上下文。

相关文章
相关标签/搜索