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

1. 引言

领域一词,主要有以下两个意思:

  1. 一国主权所达之地。

  2. 学术思想或社会活动的范围。

不管是指国家的主权范围也好还是学术活动范围,都是在讲一个范围,一个界限。
比如我们常说的,学术领域、思想领域、技术领域、语言领域、物理领域、医学领域、游戏领域、JAVA领域、.NET领域等等,它们中不管是泛指还是特指某个领域,都是限定在某个范围之内的。
由此可见领域一词重在范围的界限

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

2. DDD中的领域

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

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

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

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

所以我们的案例也就可以理解为一个基于微信公众号平台的电商领域普通电子商务网站的开发。

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

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

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

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

3. 子域

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

对于我们的案例涉及到的业务,商品、用户、订单、报价、支付、物流、报修相关业务,我们可以大致拆分成以下几个子域:

  • 商品子域

  • 用户子域

  • 销售子域

  • 订单子域

  • 支付子域

  • 物流子域

  • 维修子域

3.1 核心域

如果从几个子域中确定核心域,这也许难以决定,没关系。我们先来回答一个问题。
什么是电商网站?在线商品买卖平台。
电商领域的核心就是为了商品买卖
我们知道开发这个电商网站的目的是为了寻求推广和销售利润的最大化。
所以自然而然核心域就是销售子域了。

为什么要先确定核心域?
因为作为一个业务的核心存在,它最能体现系统的核心价值,也是核心竞争力。如果要最大化系统的价值,我们必然要在核心域的设计上更胜一筹。
确定核心域后,我们在进行开发设计的时候就有了主次之分。

3.2 通用子域

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

3.3 支撑子域

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

4. 总结

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

  • 领域是有范围界限的,也可以说是有边界的。

  • 核心域是业务系统的核心价值所在,承载着一个系统的重中之重。

  • 通用子域可以理解为业务系统所有子域的消费者,提供着通用服务。

  • 支撑子域专注于业务系统的某一重要的业务,来支撑和完善业务系统。

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

相关文章

  • DDD理论学习系列(1)-- 通用语言

  • DDD领域驱动之干货 (一)

  • 从事件和DDD入手来构建微服务

  • WeText项目:一个基于.NET实现的DDD、CQRS与微服务架构的演示案例

  • 【DDD/CQRS/微服务架构案例】在Ubuntu 14.04.4 LTS中运行WeText项目的服务端

原文地址:http://www.cnblogs.com/sheng-jie/p/6865784.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324892.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最全、最详细的配置jdk十步法!

求关注求转发大家好,我是雄雄。今天给大家分享的是 如何配置jdk ,还记得我当年刚开始自学编程时,jdk配置了好几天才配置好,说来也是惭愧啊。并且配置成功的步骤我自己都不知道是啥,因为当时是东找一个方法,…

RabbitMQ系列教程之三:发布\/订阅(Publish\/Subscribe)

在前一个教程中,我们创建了一个工作队列。工作队列背后的假设是每个任务会被交付给一个【工人】。在这一部分我们将做一些完全不同的事情--我们将向多个【消费者】传递信息。这种模式被称为“发布/订阅”。 为了说明这种模式,我们将构建一个简单的日志…

路径使用场景

路径的使用场景 路径适用的范围:jsp页面中link script img a form 等 如果访问的是其他服务器中的项目文件只可以使用绝对路径 如果访问的是同一个服务器中的其他项目推荐使用根路径 如果访问的是同一个服务器中的同一个项目中的文件推荐使用相对base标签的路径 修改…

【jzoj】2018.1.30NOIP普及组——模拟赛D组

_ 前言 写博客时间 2018/1/30 22:36。 感想:出数据的dalao我服! 正题 题目1:二项式展开式(jzoj2254) 输入一个整数,求展开(ab)^n。展开方式为 (ab)^n?a^n?a^(n-1)b?a^(n-2)b^2…?b^n 其中” ? “…

开发人员也要懂点的测试知识

转载自 开发人员也要懂点的测试知识 本文来自于作者投稿,作者陈彩华,贝聊后端开发工程师。 最近参加了保利威测试总监李乐的《互联网测试姿势》为主题的分享交流会,收获颇丰,作为一个开放,秉承“不懂产品和测试的开…

转发和重定向

需求说明 用户输入并提交登录信息 登录成功,跳转到success.jsp页面 登录失败,跳转回login.jsp页面 理解图 区别详解

实现自己的.NET Core配置Provider之Yaml

YAML是一种更适合人阅读的文件格式,很多大型的项目像Ruby on Rails都选择YAML作为配置文件的格式。如果项目的配置很少,用JSON或YAML没有多大差别。看看rails项目中的配置文件,如果用JSON写试试什么感受吧。 在《实现自己的.NET Core配置Pro…

信息时代与人工智能时代的教育变革

求关注求转发本文是雄雄的小课堂投稿的第 1 篇文章,作者:小溪时代发展迅速,学校的教育体系却没有很大的改变。比如现在的学生们还是学着几百年前的东西。试想一下,这是否真的适合我们这个时代,亦或真的需要改变了。教育…

【jzoj】2018.1.31 NOIP普及组——D组模拟赛

前言 今天题目比较水and我进了C组,不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。 正题 题1:奇数统计(jzoj1547) 就是输入n个数,输出出现次数为奇数的一个数&a…

RabbitMQ系列教程之四:路由(Routing)

在上一个教程中,我们构建了一个简单的日志系统,我们能够向许多消息接受者广播发送日志消息。在本教程中,我们将为其添加一项功能 ,这个功能是我们将只订阅消息的一个子集成为可能。 例如,我们可以只将关键的错误消息输…

【jzoj3734,Usaco2014Open银组】双导航(gpsdual)

前言 这是今天C组的题,闲得无聊做了一会,结果就对了233。这算是学了SPFA之后的第一次实战了。反正其他C组题我也不想做了。好了现在bi~~(系统自动屏蔽)也在做这道题。 还有这道题的名字叫 正题 题目 一个有向图,有…

Java代码到底是如何编译成机器指令的。

转载自 Java代码到底是如何编译成机器指令的。 在《Java代码的编译与反编译》中,有过关于Java语言的编译和反编译的介绍。我们可以通过javac命令将Java程序的源代码编译成Java字节码,即我们常说的class文件。这是我们通常意义上理解的编译。 但是&am…

DDD理论学习系列(3)-- 限界上下文

1. 引言 限界上下文可以拆分为两个词,限界和上下文。限界:是指一个界限,具体的某一个范围。上下文:个人理解就是语境。 比如我们常说的段子: “我想静静。”这个句子一般是想表达“我想静一静”的意思。但是我们却把…

分布式事务解决方案——柔性事务与服务模式

转载自 分布式事务解决方案——柔性事务与服务模式 初识分布式系统 关于分布式一致性的探究 分布式系统的CAP理论(需要到博客中查看) 分布式系统的BASE理论(需要到博客中查看) Java中的事务——JDBC事务和JTA事务 Java中的…

“温室里的花朵”也要直面困难

求关注求转发本文是雄雄的小课堂投稿的第 2 篇文章,作者:小溪“花朵”在爸妈的细心培育下成长。可它们不知道未来是怎样的,它们对未来充满着想象与渴望,却没有人曾告诉它们,这个世界布满荆棘,而“花朵们”也…

Visual Studio 2015和2017里面应该创建哪种 Class Library

微软有些时候是一副不讲道理的大家长作风。一个例子就是它在 Visual Studio 2015/2017 里面配置了一大堆普通人没法理解的 Class Library 模板。 你真的知道应该选哪个吗? 这就是 VS2017 里面你可能熟悉的长列表(而且因为我没有安装 UWP 开发项目&#…

win10操作技巧介绍,很实用!

求关注求转发本文是雄【雄的小课堂】原创的第 136 篇文章1.wind:返回桌面不管你当前所在的什么窗口,一键即可切换到桌面,有时候称之为“老板键”2.wine:打开计算机我最喜欢用了,不管你在任何窗口,一键打开计算机,相比去…

深入理解分布式系统中的缓存架构(上)

转载自 深入理解分布式系统中的缓存架构(上) 本文主要介绍大型分布式系统中缓存的相关理论,常见的缓存组件以及应用场景。 1 缓存概述 2 缓存的分类 缓存主要分为以下四类 2.1 CDN缓存 基本介绍 CDN(Content Delivery Network 内容分发网络)的基本原理是广泛…

微软向开发者推出区块链概念验证框架

微软在近期的一篇博文中宣布了一个新的框架,用以在Azure云平台上加速已通过企业概念验证(PoC)的区块链部署。微软希望用户能在可支持分布式账本(DLT)解决方案的基础设施上,借助于灵活的契约和更少的时间&am…

Cookie和Session 登录

Cookie 实现免登陆和Session 01、 需求说明 完成用户登录功能 登录成功后跳到成功页面,显示用户名 登录失败可以跳回登录页面 登录成功后后续操作均能显示当前登录的用户名 02、完成代码 DologinServlet.java Override protected void service(HttpServletRequest req, Http…