一文揭秘领域驱动设计(DDD):领域和子域
ccwgpt 2024-10-13 01:27 28 浏览 0 评论
★★★建议星标我们★★★
2020年Java原创面试题库连载中
【000期】Java最全面试题库思维导图
【020期】JavaSE系列面试题汇总(共18篇)
【028期】JavaWeb系列面试题汇总(共10篇)
【042期】JavaEE系列面试题汇总(共13篇)
【049期】数据库系列面试题汇总(共6篇)
【053期】中间件系列面试题汇总(共3篇)
【065期】数据结构与算法面试题汇总(共11篇)
【076期】分布式面试题汇总(共10篇)
【077期】综合面试题系列(一)
【078期】综合面试题系列(二)
【079期】综合面试题系列(三)
【080期】综合面试题系列(四)
【081期】综合面试题系列(五)
【082期】综合面试题系列(六)
【083期】综合面试题系列(七)
【084期】综合面试题系列(八)
【085期】综合面试题系列(九)
【086期】综合面试题系列(十)
【087期】综合面试题系列(十一)
【088期】综合面试题系列(十二)
【089期】综合面试题系列(十三)
更多内容,点击上面蓝字查看
- 前言 -
众所周知,领域驱动设计(DDD)是个相当抽象的概念,国内除了几家知名大厂有成功实践外,更多技术团队还处于探索阶段。想要以 DDD 思想指导架构设计,我们首先需要对 DDD 所包含的概念有深入了解,今天,就和大家简单聊聊 DDD 的核心概念:领域和子域。
- 领域和子域 -
在很长一段时间里,我们认为技术是主导项目成功的关键因素,这种关键因素通常表现在项目使用的编程语言、框架、架构(如:分层架构)、中间件、数据库等等方面(如:生态)。但技术真的是项目成功的关键因素吗?
在一个软件项目里除了技术层面的这部分,我们最主要的事情是实现业务。实现业务其实是在实现所在业务领域中所需要的业务。技术也是一个领域,称之为技术领域。领域驱动设计中的领域是指的业务领域。
大多数的技术人员对技术领域中的知识比较感兴趣(狂热),因为这能够使得自己在技术方面有一些前沿性和探索性的实践。然而对于业务领域中的知识就显得比较暗淡一些。
当项目的进展随着对业务领域的深入,大家又开始为各种曾经没有分析到的需求忙的焦头烂额。这个时候对技术领域的探索也基本成熟。接着又一轮新技术的出现,使得大家又开始对新技术进行探索实践,并试图使用新技术来解决掉以前遗留下来的没有解决的新需求,此时就出现了所谓的“全盘重构”。
正是这种周而复始的对技术领域的不断探索,使我们对业务领域里重要的核心知识被埋没。当有一天我们认识到业务领域十分重要时,你可能已经不在这个业务领域中探索技术了。
让一个技术水平较高的技术人员去深入研究分析领域中的业务是需要勇气的,这种勇气不是来自对未知的复杂业务领域的挑战而是让自己不在无时无刻沉静在对技术探索的环境中。
这要求一些技术人员需要花费一些时间去深入到业务领域中去分析领域知识并最终形成领域模型。
问题:领域中的业务是由什么组成的呢?
回答:需求。
问题:需求又是有什么组成的呢?
- 什么是领域? -
百度百科对领域的解释:
学术思想或社会活动的范围。
具体指一种特定的范围或区域。
在《领域驱动设计》中,领域指的是一个特定的业务范围,大家在这个业务域范围内开展工作。
领域这个词承载了太多的含义。在大多数人的理解中会使用领域代替行业、项目或者系统,这样会使一些人认识领域就是行业、项目或者系统。在认识领域时一定要注意所指的业务域,行业、项目或系统都不能准确地表达领域所指的业务域。
一个系统可能由一个领域或者多个领域组成。如果一个系统是由一个领域组成时,这会给大家一种错觉。
1、子域(Subdomain)
在初识子域概念时,可能会认为子域与领域的是父子关系。其实他们并不是父子关系,而是包含关系。当多个业务域(领域)的组合形成了一个更大的业务域(领域)时,其中每一个领域(业务域)是这个更大的业务域的一部分,每一个业务域相对于这个更大的业务域称之为这个更大领域的子业务域,简称子域。组合而成的这个更大的业务域统称为领域。
补充:领域与子域的关系更好的描述是饼状图,领域相当于整个饼状图,子域相当于这个饼状图中的某一个块。
这是一个有关“零售商在线销售产品”的例子,来源于《实现领域驱动设计》。
把零售商中的所有业务看做成一个领域(业务域),把这个整体业务域中的每一个业务域看做成子域。所以这个零售商业务域中包括:产品目录子域、订单子域、物流子域、发票子域、库存子域等。
这张业务域图已经为我们呈现了一个近似完整的子域划分图。那么这张图是如何完成划分的呢?
对一个业务域划分子域时,往往会把一个领域划分为:核心域、支撑子域、通用子域三种类型的子域集。其中核心域是整个业务域(领域)的核心,支撑子域和通用子域完成非核心的业务。不管怎么样,在对一个整体业务域进行划分时,首先要做的是划分核心域。
注意:三种类型的子域不是三个类型的子域,每种类型的子域数量可能有多个。
2、核心域(Core Domain)
核心域是整个业务系统的核心,所有的业务都要围绕着核心业务域展开。如何明确核心域呢?
通常明确核心的方式是精炼业务域。精炼是一个持续的过程,具体来说有以下几种方式:
领域愿景说明(Domain Vision Statement)
突出核心(Highlighted Core)
内聚机制(Cohesive Mechanism)
分离的核心(Segregated Core)
抽象核心(Abstract Core)
3、领域愿景说明(Domain Vision Statement)
这部分的内容在《领域驱动设计》中表达地非常简洁,没有必要再做过度的解读。具体内容如下:
并且还给出了两个“领域愿景说明”的示例:
在这两个示例中提到的模型并不是一个领域模型,而是一组领域模型。更具体地来说是要告诉我们这一组领域模型要解决什么问题,而这个要解决的问题正是由客户来提出的最需要的那个功能,这个最需要的功能正是业务域中的核心。
为业务域编写“领域愿景说明”是有必要的,因为它可以让整个团队的人员都能明确什么是核心域。正是明确了核心域,才可以使整个团队朝着统一的方向前进。
4、突出核心(Highlighted Core)
我们通过“领域愿景说明”可以明确什么是核心域,但这是从一个较为宽泛的角度对核心域进行说明的。我们明确核心域的目的是为了形成核心领域模型,此时我们需要突出核心。
突出核心域中的领域模型有两种方式:
精炼文档;
标明核心(Core)。
精炼文档要做的事情是创建一个最核心的概念对象的清单文档。
标明核心(Core) 要做的事情是从一个完整的领域模型文档中标记出最核心的领域模型。
5、分离的核心(Segregated Core)
分离的核心的主要目的有两个:
将核心域中的非核心元素(模型)分离出去。
将非核心域中的核心元素(模块)移动到核心域中。
这两个目的都是为了让核心域更加清晰和增强核心域的内聚性。
有关核心域的更多内容请阅读《领域驱动设计》中的第十五章,其中非常详细地阐述了如何明确核心域和实现核心域。
《实现领域驱动设计》中通过问题空间和解决方案空间对核心域做了更直接的说明:
问题空间是领域的一部分,对问题空间的开发将产生一个新的核心域。[IDDD, P48]
核心域的范围并不一定是一次就能确认的,可能需要迭代很多次,每一次都有可能扩大或缩小。
6、通用子域
如果一个子域不是核心域并且被用于整个业务系统,那么这个子域便是通用子域。[IDDD, P44]
通用子域:模型中有你想当然的部分。不可否认,它们确实是领域模型的一部分,但它们抽象出来的概念是很多业务都需要的。比如:各个行业(如:运输业、银行业或制造业)都需要某种形式的企业组织图。[DDD, P282]
这两段摘取为我们描述出什么是通用子域,从业务域的角度来看,通用子域也是一种业务域,和核心域一样。只是没有核心域的优先级高。因为核心域是整个系统的核心,整个系统因为核心域才具有竞争性。而通用子域只是那些提供的增强功能,比如电商系统中的商品收藏、店铺收藏、用户信息等等这些功能,它们确实是电商系统中的业务,但是并不是核心业务,这些增强性的业务就是通用子域。
注意:有些小伙伴会把通用子域与共享内核混淆,是因为共享内核的组成部分既有可能是核心域、支撑子域或者通用子域。
7、支撑子域
在业务域中,会有一些比较重要的业务,但却不是核心,那么它便是一个支撑子域。创建支撑子域的原因在于它们专注于业务的某个方面。它不像核心域在整个系统中那么重要,也不像通用子域。
8、开源电商
Mallfoundry 是一个完全开源的使用 Spring Boot 开发的多商户电商平台。它可以嵌入到已有的 Java 程序中,或者作为服务器、集群、云中的服务运行。
领域模型采用领域驱动设计(DDD)、接口化以及面向对象设计。
项目地址:gitee.com/mallfoundry…
- 总结 -
在一个业务域中,基本由三种类型的子域组成,分别是:核心域、通用子域和支撑子域。在分析业务域时,首先要做的事情是分析核心域,然后设计核心域,这样就能明确系统的最主要的功能。
围绕着这个核心域进行展开,慢慢添加其它子域,比如通用子域和支撑子域。在开发核心域和其它子域时,要为核心域分配最高的优先级,其它子域可以根据任务的多方面因素在分配优先级。
来源:掘金
链接:https://juejin.cn/post/6898450822771539981
之前,给大家发过三份Java面试宝典,这次新增了一份,目前总共是四份面试宝典,相信在跳槽前一个月按照面试宝典准备准备,基本没大问题。
《java面试宝典5.0》(初中级)
《350道Java面试题:整理自100+公司》(中高级)
《资深java面试宝典-视频版》(资深)
《Java[BAT]面试必备》(资深)
分别适用于初中级,中高级,资深级工程师的面试复习。
内容包含java基础、javaweb、mysql性能优化、JVM、锁、百万并发、消息队列,高性能缓存、反射、Spring全家桶原理、微服务、Zookeeper、数据结构、限流熔断降级等等。
看到这里,证明有所收获
相关推荐
- 十分钟让你学会LNMP架构负载均衡(impala负载均衡)
-
业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...
- AGV仓储机器人调度系统架构(agv物流机器人)
-
系统架构层次划分采用分层模块化设计,分为以下五层:1.1用户接口层功能:提供人机交互界面(Web/桌面端),支持任务下发、实时监控、数据可视化和报警管理。模块:任务管理面板:接收订单(如拣货、...
- 远程热部署在美团的落地实践(远程热点是什么意思)
-
Sonic是美团内部研发设计的一款用于热部署的IDEA插件,本文其实现原理及落地的一些技术细节。在阅读本文之前,建议大家先熟悉一下Spring源码、SpringMVC源码、SpringBoot...
- springboot搭建xxl-job(分布式任务调度系统)
-
一、部署xxl-job服务端下载xxl-job源码:https://gitee.com/xuxueli0323/xxl-job二、导入项目、创建xxl_job数据库、修改配置文件为自己的数据库三、启动...
- 大模型:使用vLLM和Ray分布式部署推理应用
-
一、vLLM:面向大模型的高效推理框架1.核心特点专为推理优化:专注于大模型(如GPT-3、LLaMA)的高吞吐量、低延迟推理。关键技术:PagedAttention:类似操作系统内存分页管理,将K...
- 国产开源之光【分布式工作流调度系统】:DolphinScheduler
-
DolphinScheduler是一个开源的分布式工作流调度系统,旨在帮助用户以可靠、高效和可扩展的方式管理和调度大规模的数据处理工作流。它支持以图形化方式定义和管理工作流,提供了丰富的调度功能和监控...
- 简单可靠高效的分布式任务队列系统
-
#记录我的2024#大家好,又见面了,我是GitHub精选君!背景介绍在系统访问量逐渐增大,高并发、分布式系统成为了企业技术架构升级的必由之路。在这样的背景下,异步任务队列扮演着至关重要的角色,...
- 虚拟服务器之间如何分布式运行?(虚拟服务器部署)
-
在云计算和虚拟化技术快速发展的今天,传统“单机单任务”的服务器架构早已难以满足现代业务对高并发、高可用、弹性伸缩和容错容灾的严苛要求。分布式系统应运而生,并成为支撑各类互联网平台、企业信息系统和A...
- 一文掌握 XXL-Job 的 6 大核心组件
-
XXL-Job是一个分布式任务调度平台,其核心组件主要包括以下部分,各组件相互协作实现高效的任务调度与管理:1.调度注册中心(RegistryCenter)作用:负责管理调度器(Schedule...
- 京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?
-
京东大佬问我,SpringBoot中如何做延迟队列?单机如何做?分布式如何做呢?并给出案例与代码分析。嗯,用户问的是在SpringBoot中如何实现延迟队列,单机和分布式环境下分别怎么做。这个问题其实...
- 企业级项目组件选型(一)分布式任务调度平台
-
官网地址:https://www.xuxueli.com/xxl-job/能力介绍架构图安全性为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;调度中心和执...
- python多进程的分布式任务调度应用场景及示例
-
多进程的分布式任务调度可以应用于以下场景:分布式爬虫:importmultiprocessingimportrequestsdefcrawl(url):response=re...
- SpringBoot整合ElasticJob实现分布式任务调度
-
介绍ElasticJob是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目ElasticJob-Lite和ElasticJob-Cloud组成。它通过弹性调度、资源管控、...
- 分布式可视化 DAG 任务调度系统 Taier 的整体流程分析
-
Taier作为袋鼠云的开源项目之一,是一个分布式可视化的DAG任务调度系统。旨在降低ETL开发成本,提高大数据平台稳定性,让大数据开发人员可以在Taier直接进行业务逻辑的开发,而不用关...
- SpringBoot任务调度:@Scheduled与TaskExecutor全面解析
-
一、任务调度基础概念1.1什么是任务调度任务调度是指按照预定的时间计划或特定条件自动执行任务的过程。在现代应用开发中,任务调度扮演着至关重要的角色,它使得开发者能够自动化处理周期性任务、定时任务和异...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- JAVA集合框架 (47)
- grpc框架 (55)
- ppt框架 (48)
- 内联框架 (52)
- winform框架 (46)
- gui框架 (44)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)