本片将介绍以下内容:

  1).DDD是什么?

  2).怎么使用DDD?

  3).使用DDD应该规避或者注意什么?

一.DDD是什么?

简言之:领域驱动设计(domain driven design),顾名思义,着重点在领域,这里的领域指的就是具体的业务领域,一个业务可以是一个领域或者多个子领域,每个领域中包含多个子域.具体的实现更偏重于具体的业务知识,而不是技术的细节,说白了技术无关性了.

2. 我们如何开始?

开始使用需要领域专的参与,需要领域专家对相应领域的业务分析,分析过程要注意 限界上下文:

1.核心域

  整个业务的核心领域并划分限界上下文

2.支撑域

  支撑其他域的域,,,,好像有点蛋疼的说法,举个栗子:假设当前系统为电商系统,其中涉及到订单这个核心模块,这个订单就可以独立成一个核心域,但是问题来了,订单会涉及到用户信息,以及用户账户是否正常是否被冻结等权限的判断,那么这个用户的信息的内容可以独立成一个子域,但是还一个问题,不只是订单会用到用户信息,留言\评论\等等都会用到吧,那么到这里就很明显了,这个就是所谓的支撑域了

3.通用域

  顾名思义,通用的模块或者功能或者插件或第三方成熟的功能等等,比如,ids4.日志,中介插件,熔断重试等等

3.使用DDD应该规避或者注意什么 ?

DDD实现,另一方面,在我们我们需要注意点。这些都是:

1)使用一个以数据为中心的视图建模时的问题域

通常,数据模型的第一件事是一个架构师/开发人员将开始设计。他们总是认为数据是最重要的,因为数据是我们需要报告。如果你开始与DDD,必须改变这种心态。数据本身是没有意义的。只有逻辑给数据意义,相同的数据可以在不同的上下文中有不同的含义。因此,我们必须从上下文和逻辑,而不是数据。

2)专注于实现细节等实体、值对象、服务、工厂、和存储库的核心概念

实体、值对象存储库等等没有意义,直到我们定义了通用语言,有界的情况下,合同/制作软件的接口。如果我们开始早期与实体等实现细节,这是个好机会,结果将是一个域周围很多服务和业务逻辑分散无处不在。

3)使用泛型和Developer-Specific术语和概念在实现应用程序

我们不应该使用概念,比如保存、更新、删除、处理、管理、等。这些概念太技术——抽象的概念,没有具体的意义。相反,我们必须专注于业务概念。上述的概念(即保存、更新等)不相关的业务概念。要理解这一点,我总是鼓励自己想象没有电脑客户端运行他的差事/业务(手动做特定的任务)。所以,总是想从业务/领域专家的角度来看,和给一个明确的上下文。避免通用术语,可导致不同的含义在不同,非特异性背景。

4)高估了数据库事务,而不是专注于业务流程或事务

在DDD,商业交易比DB更重要的事务。数据库事务是ACID(原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)),和短时间运行的,而商业交易。事实上,在现实生活中,我们不知道数据库事务,了解业务事务。例如,想象一下当你坐在餐厅,点一些食物或饮料。在订单事务,实现与否,将会有一个过程与一些异步任务很多可能的变化不一致的状态;但最后,所有状态都将一致(最终一致)。因此,与DDD,永远不要考虑数据库事务。相反,总是思考现实世界的过程,如行为和可能的结果,如果发生失败如何弥补该行为或结果。

DDD - 概述 - (一)的更多相关文章

  1. DDD - 概述 - 聚合 - 限界上下文 (四)

    最重要的一句话 DDD的所有有相关理论中,只有一句是至关重要的,但是也是最容易被忽略和最难做到的,抛弃传统的设计方式(思路)的思想,这句话起了决定性的作用,但是99%的人都忽略了或者在开始无法正视或理 ...

  2. DDD - 概述 - 模块 (二)

    首先,你必须知道以下DDD构建块: Entities - 实体 Value objects - 值对象 Aggregate roots - 聚合跟 Repositories - 仓储对象 Factor ...

  3. DDD - 概述 - 聚合 (三)

    不要再看那些理论啦,说的云里雾里的,绕到你怀疑人生 一句话概括聚合创建:聚合的一致性决定了聚合边界的确定,决定了聚合对象的创建.所谓的一致性即事务的一致性,细化就是 立即性和原子性.

  4. DDD兴起的原因以及与微服务的关系

    DDD为什么能火起来? 我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景, 根据我学习的套路, 永远是为什么为先,再是解决什么问题,是什么东西, 最后如何使用.我们都知道这些年随着设备以及技术 ...

  5. 对DDD使用的一些建议

    群里经常看到类似于"看了DDD之后就不会写代码了"的情况,趁最近学车的间隙,写写我的看法. 关于这个事儿,我是觉得:当没有DDD的时候,如果你知道怎么做,那就那么做好了,不要考虑D ...

  6. DDD实战进阶第一波(一):开发一般业务的大健康行业直销系统(概述)

    本系列文章 DDD实战进阶第一波(一):开发一般业务的大健康行业直销系统(概述) DDD实战进阶第一波(二):开发一般业务的大健康行业直销系统(搭建支持DDD的轻量级框架一) 近年来,关于如何开发基于 ...

  7. 领域模型驱动设计(Domain Driven Design)入门概述 -----DDD 解释

    软件开发要干什么: 反映真实世界要自动化的业务流程 解决现实问题 领域Domain Domain特指软件关注的领域 在不能充分了解业务领域的情况下是不可能做出一个好的软件 领域建模 领域模型驱动设计 ...

  8. DDD领域驱动设计-概述-Ⅰ

     如果我看得更远,那是因为我站在巨人的肩膀上.(If I have seen further it is by standing on ye shoulder of Giants.)         ...

  9. DDD中Dto领域驱动设计概述,摘自《NET企业级应用架构设计》

随机推荐

  1. 定向耦合器 Directional Couplers

    microwave101,干货比较多 传送门:https://www.microwaves101.com/encyclopedias/directional-couplers Directional ...

  2. ORA-00923: FROM keyword not found where expected(单双引号)

    1.前提 在学习oracel的过程中遇到的一个关于单双引号的问题 备注一下 2.学习过程中创建表语句是这样的 create table DEPT_DML --部门表( DEPT_NO NUMBER(8 ...

  3. CMakeList.txt(3): 一个cmake实例

    介绍一个比较实用的例子,即包含生成静态库又包含引入外部头文件和链接库的cmake demo. 先按照工程规范建立工程目录,并编写代码,以下面的工程目录为例进行解释这个例子,工程的目录结构为: 1. 编 ...

  4. windows一键部署java项目

    windows一键部署java项目 因为公司需求,要在windows的环境上做一键部署启动java项目,同时还要支持从安装界面动态修改配置文件的IP地址.就像安装软件一样将jdk,tomcat,mys ...

  5. VMware 安装Linux系统 CentOS

    VMware 安装Linux系统 CentOS 1.  下载镜像系统 centos镜像下载地址:https://www.centos.org/download/ 选择DVD下载即可 linux各版本下 ...

  6. i-83.net quadhost子产品

    i-83.net 6$一年, 首年半价, 优惠码: APR19-NAT50 加拿大 ---------------------------------------------------------- ...

  7. 课程设计个人报告——基于ARM实验箱的捕鱼游戏的设计与实现

    课程设计个人报告--基于ARM实验箱的捕鱼游戏的设计与实现 一.个人贡献 参与课设题目讨论及部分过程 资料收集 负责代码调试 捕鱼游戏相应功能的实现 实验环境 Eclipse软件开发环境: ARM实验 ...

  8. vue组件通讯方法汇总(在不使用vuex的情况下)

    前三种是父子组件通讯,最后一种是平级组件.

  9. VS Code保存使用项目Eslint规则格式化代码

    One.文件-首选项-设置-选择项目                  Two.打开右上角JSON设置            Three. 插入以下代码 { "eslint.options& ...

  10. recurrent model for visual attention

    paper url: https://papers.nips.cc/paper/5542-recurrent-models-of-visual-attention.pdf year: 2014 abs ...