北风网项目培训基于SOA思想下的WebService实战讲师:Sean第08讲领域模型驱动设计什么是领域驱动设计基本构成要素领域模型参考架构软件开发◦反应真实世界要自动化的业务流程◦或者可以用软件解决的现实问题Domain特指软件关注的业务领域在不能充分理解业务领域的情况下,无法做出一个好的软件特定业务领域的知识映射类,方法算法,模式对象之间关系封装,继承,多态面向对象编程数据库,表,字段类库,框架专业技能专业技能专业技能专业技能专业技能专业技能专业技能用模型来交流领域专家软件专家采集业务名词-类采集业务动词-方法表现形式多样(UML|文档|小图|代码)确保软件专家和领域专家能在一起能快速读懂并交流产生的交流结果能简单传达到给其他领域专家分层架构实体值对象服务模块聚合工厂资源库将领域模型相关的代码集中到一个层中,把它从用户界面、应用和基础设施代码中分隔开来释放领域对象的显示自己、保存自己、管理应用任务等职责,让它专注于展现领域模型复杂的程序切分成层层中采用内聚的设计层仅依赖于它底下的那层有一类对象拥有唯一标识符能够跨越系统的生命周期甚至能超越软件系统的一系列的延续性和标识符这样的对象称为实体。对某个对象是什么不感兴趣,只关心它拥有的属性用来描述领域的特殊方面、且没有标识符的一个对象,叫做值对象能被简单的创建和丢弃,生命周期中不会被持久化值对象可以被共享,值对象应该不可变DTO枚举值自定义异常临时对象领域中的一些动词,代表了领域中的一个重要的行为,却不属于任何对象◦服务执行的操作涉及一个领域概念,这个领域概念通常不属于一个实体或者值对象◦被执行的操作涉及到领域中的其他的对象◦操作是无状态的服务对象不再拥有内置的状态服务对象担当重要的协调功能银行转账将相关领域模型提炼分类,分而治之将高关联度的模型分组到一个模块以提供尽可能大的内聚(以能完整完成任务为准)分层是水平划分模块是垂直划分(Domain内部)所有权和边界创建存储聚合模式工厂模式资源库模式聚合是针对数据变化可以考虑成一个单元的一组相关的对象实体实体实体实体实体根对象外部调用增删改查值对象Copy操作根对象工厂封装复杂的对象创建过程(特别是聚合根对象)实体实体实体实体实体根对象外部调用工厂设计模式参考实现:简单工厂工厂方法抽象工厂newFactory.build资源库的目的是封装所有获取对象引用所需的逻辑。领域对象不需处理基础设施,以得到领域中对其他对象的所需的引用实体实体实体实体实体根对象外部调用资源库工厂关注的是对象的创建资源库关注的是已经存在的对象find基础设施selectbuild领域驱动设计(DomainDrivenDesign)有一个官方的sample工程,名为DDDSample官网:该工程给出了一种实践领域驱动设计的参考架构该层包含与其他系统进行交互的接口与通信设施,在多数应用里可能提供包括WebServices、RMI或Rest等在内的一种或多种通信接口该层主要由Facade、DTO和Assembler三类组件构成,三类组件均是典型的J2EE模式DTO-DataTransferObject(数据传输对象),也常被称作VO-ValueObject(值对象)DTO设计之初是为了将细粒度的领域对象包装为粗粒度的数据结构,减少网络通信并简化调用接口减少网络流量简化远程对象和远程接口传输更多的数据减少远程调用次数避免将领域状态跨层次传递由于同步和版本控制增加了复杂性DTO与领域对象之间的相互转换工作多由Assembler承担因此Assembler几乎总是同DTO一起出现。装配工实践Facade的过程中最难把握的问题就是Facade的粒度问题。传统的Service均以实体为单位进行组织,而Facade应该具有更粗粒度的组织依据,较为合适的粒度依据有:一个高度内聚的模块一个Facade或者是一个“聚合”(特指领域驱动设计)一个Facade.应用层负责驱动应用程序的工作流程,匹配对应的UseCase,由Interfaces层通过同步或异步消息驱动这一层是适合生成交易,高等级日志logging和安全性应用层在领域逻辑中是很薄的一层,只负责协调领域层对象去执行实际的工作Service会与多种组件进行交互这些组件包括:◦其他的Service◦领域对象◦Repository◦DAODomain层是整个系统的核心层,该层维护一个使用面向对象技术实现的领域模型,几乎全部的业务逻辑会在该层实现Domain层包含:◦Entity(实体)◦ValueObject(值对象)◦DomainEvent(领域事件)◦Repository(仓储)等基础设施层nfrastructure为Interfaces、Application和Domain三层提供支撑所有与具体平台、框架相关的实现会在Infrastructure中提供,避免三层特别是Domain层掺杂进这些实现,从而“污染”领域模型Infrastructure中最常见的一类设施是对象持久化的具体实现DDD领域模型驱动设计SOA面向服务的架构欢迎访问我们的官方网站