领域驱动设计(DDD:Domain-Driven Design)转

出处:http://blog.csdn.net/johnstrive/article/details/16805121
说明:找了很多文章,看上去就像哲学论文一样,并不能理解(看来还是要实践中领悟了)。不过这篇文章让我看懂一个大概的意思,所以记录一下。

软件开发要干什么:

反映真实世界要自动化的业务流程
解决现实问题

领域Domain

Domain特指软件关注的领域
在不能充分了解业务领域的情况下是不可能做出一个好的软件

领域建模





领域模型驱动设计
} 分层架构
} 实体
} 值对象
} 服务
} 模块
} 聚合
} 工厂
} 资源库

分层架构:


} 将领域模型相关的代码集中到一个层中,把它从用户界面、应用和基础设施代码中分隔开来
} 释放领域对象的显示自己、保存自己、管理应用任务等职责,让它专注于展现领域模型
} 复杂的程序切分成层
} 层中采用内聚的设计
} 层仅依赖于它底下的那层

实体entity:有一类对象拥有唯一标识符
} 能够跨越系统的生命周期甚至能超越软件系统的一系列的延续性和标识符
} 这样的对象称为实体。
值对象-value Object
} 对某个对象是什么不感兴趣,只关心它拥有的属性
} 用来描述领域的特殊方面、且没有标识符的一个对象,叫做值对象
} 能被简单的创建和丢弃,生命周期中不会被持久化
} 值对象可以被共享,值对象应该不可变
服务-service(比webservice更细粒度服务描述)
} 领域中的一些动词,代表了领域中的一个重要的行为,却不属于任何对象
◦ 服务执行的操作涉及一个领域概念,这个领域概念通常不属于一个实体或者值对象
◦ 被执行的操作涉及到领域中的其他的对象
◦ 操作是无状态的
} 服务对象不再拥有内置的状态
} 服务对象担当重要的协调功能
} 开发通用语言时,领域中的主要概念被引入到语言中,语言中的名词很容易被映射成对象。
语言中对应那些名词的动词变成那些对象的行为。但是有些领域中的动作,它们是一些动词,看上去却不属于任何对象。它们代表了领域中的一个重要的行为,所以不能忽略它们或者简单的把它们合并到某个实体或者值对象中。给一个对象增加这样的行为会破坏这个对象,让它看上去拥有了本该属于它的功能。

模块
} 将相关领域模型提炼分类,分而治之
} 将高关联度的模型分组到一个模块以提供尽可能大的内聚(以能完整完成任务为准)
} 分层是水平划分
} 模块是垂直划分(Domain内部)




参考架构概述
} 领域驱动设计(DomainDriven Design)有一个官方的sample工程,名为DDDSample
} 官网:http://dddsample.sourceforge.net/
} 该工程给出了一种实践领域驱动设计的参考架构
架构概述


详细架构

架构详解:Interfaces-接口层

} 该层包含与其他系统进行交互的接口与通信设施,在多数应用里
} 可能提供包括WebServices、RMI或Rest等在内的一种或多种通信接口
} 该层主要由Facade、DTO和Assembler三类组件构成,三类组件均是典型的J2EE模式
DTO

} DTO- DataTransfer Object(数据传输对象),也常被称作VO-ValueObject(值对象)
} DTO设计之初是为了将细粒度的领域对象包装为粗粒度的数据结构,减少网络通信并简化调用接口
DTO 作用
} 减少网络流量
} 简化远程对象和远程接口
} 传输更多的数据减少远程调用次数
} 避免将领域状态跨层次传递
} 由于同步和版本控制增加了复杂性
DTO 应用时序图

Assembler

} DTO与领域对象之间的相互转换工作多由Assembler承担
} 因此Assembler几乎总是同DTO一起出现。
Assembler 实现方案

Façade

} 实践Facade的过程中最难把握的问题就是Facade的粒度问题。
} 传统的Service均以实体为单位进行组织,而Facade应该具有更粗粒度的组织依据,较为合适的粒度依据有:
} 一个高度内聚的模块一个Facade
} 或者是一个“聚合”(特指领域驱动设计)一个Facade.
Facade 实现方案

Facade 应用时序图

Service

} Service会与多种组件进行交互
} 这些组件包括:
◦ 其他的Service
◦ 领域对象
◦ Repository
◦ DAO
Service 应用时序图

Domain-领域层

} Domain层是整个系统的核心层,该层维护一个使用面向对象技术实现的领域模型,几乎全部的业务逻辑会在该层实现
} Domain层包含:
◦ Entity(实体)
◦ ValueObject(值对象)
◦ Domain Event(领域事件)
◦ Repository(仓储)等
Infrastructure-基础设施层

} 基础设施层nfrastructure为Interfaces、Application和Domain三层提供支撑
} 所有与具体平台、框架相关的实现会在Infrastructure中提供,避免三层特别是Domain层掺杂进这些实现,从而“污染”领域模型
} Infrastructure中最常见的一类设施是对象持久化的具体实现
“传统”架构-贫血领域模型

DDD && SOA
} DDD 领域模型驱动设计
} SOA 面向服务的架构

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容