DDD—领域模型映射代码结构

一、一级代码目录
         前面《DDD—分层架构,洋葱架构,六边形架构》一文中讲到,领域模型的业务逻辑从领域层,应用层到用户接口层逐层组合和封装,对外提供灵活的服务,既实现了各层的分工和解耦,也实现了各层的协作,DDD分层架构是微服务代码结构的最佳落地。
   

   

 

  根据DDD的分层架构,我们可以首先根据各层的单一职责定义一级目录(各层具体的职责见《DDD—分层架构,洋葱架构,六边形架构》)如下图:
   interfaces:用户接口层
   application:应用层
   domain:领域层
   infrastructure:基础层
  
 
二、各层代码目录
     用户接口层:interfaces目录下的代码目录结构有assembler,dto和facade三类
     assembler:实现前端传输数据到后端的载体DTO和DO领域对象的转换,assembler都是和DTO和DO一起出现
     dto:前端传输数据到后端的载体,不实现任何业务逻辑
     facade:封装应用服务,提供粗粒度的调用接口
    
 
    应用层:application目录下的代码目录结构有event的订阅和发布,编排领域层的应用service,同时应用层负责与外部微服务交互,可能有DTO和DO的转换过程,需要Assembler的参与
    event.publish:存放事件发布的代码
    event.subscribe:存放事件订阅的代码
    service:应用服务,对多个领域服务和外部微服务调用的封装,编排和组合,对用户接口层提供流程上的核心业务逻辑
 
  
    领域层:domain目录下是由一个或多个独立的聚合目录构成,每一个聚合是一个独立的业务功能单元,多个聚合共同实现领域模型的核心业务逻辑,聚合文件夹可以以聚合名称命名,聚合内包含entity,event,repository和service四个子目录。
    entity:存放聚合根,实体和值对象
    event:存放事件实体,以及事件的具体业务逻辑实现
    service:存放跨聚合编排的领域服务,以及PO和DO转换和初始化用的工厂
    repository:一个聚合只能有一个仓储,仓储一般包含仓储接口和仓储实现。同事仓储还会有DAO代码的具体实现
    
    
     基础层:主要存放配置信息config和各种第三工具,API,组件集成的工具类utils
    
 
     领域模型映射成微服务代码结构的最终目录组织结构如下:
    
 
 
  

  参考书籍 ——《基于DDD和微服务的中台架构与实现》欧创新、邓頔
  参考书籍 ——《领域驱动设计》Eric Evans
  参考书籍 ——《架构真经》Martin L. Abbott

posted @ 2021-06-01 13:34  纪煜楷  阅读(3648)  评论(0编辑  收藏  举报