V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
that24
V2EX  ›  Java

大佬们好,落地 DDD 时有两个迷惑我的问题, application 可以互相调用吗?调用 RPC 也需要创建与之对应的领域吗?

  •  
  •   that24 · 2021-09-30 11:35:07 +08:00 · 1827 次点击
    这是一个创建于 910 天前的主题,其中的信息可能已经有所发展或是发生改变。

    大佬们好,在落地 DDD 中遇到了两个问题,感激不尽~

    1. 项目中要用 http 调用外部的订单服务 rpc,取回来之后本有一些值要做逻辑转换处理,需要创建与之对应的领域 OrderDomain 吗?如果没有领域,那么 application 层就要做这逻辑,似乎违背了高内聚?还是说封装一个请求此 rpc 的方法,然后做一些逻辑转换即可?

    2. application 可以互相调用吗?举例如下(不用太纠结例子的合理性,主要想表达重复逻辑相互调用的问题)

      //伪代码,假设购物车,和订单是两个领域
      class OrderApplicationService {
          create(List<Integer> productIds) {
              //调用订单领域创建订单
              orderDomainService.create();
              
              //调用购物车领域删除商品
              buyCarDomainService.delete();
          }
      
      }
      

      后面出现了另一个需求比如优惠一键购买之类(只是个例子),这里同样有创建订单的逻辑,可直接调用吗?还是说再提一个 facede 层,来组合两个 application 层的方法?那如果后面 facede 层又存在相同逻辑要调用呢.....

      class BuyCombinationApplicationService(Integer relationId) {
      	//获取组合商品信息
          	List<Integer> productIds = productDomainService.getListByRelationId();
          
      	//下面的逻辑和上面的 OrderApplicationService.create 一致
      	//调用订单领域创建订单
      	orderDomainService.create();
      	//调用购物车领域删除商品
      	buyCarDomainService.delete();
      } 
      

    期待你的回复~

    2 条回复    2021-10-08 11:24:38 +08:00
    thtznet
        1
    thtznet  
       2021-09-30 11:54:11 +08:00
    物理世界中的业务映射成领域,领域与领域(跨领域)的逻辑交互通过领域服务,应用服务上接表现层的命令,判断所需的领域服务并调用。
    that24
        2
    that24  
    OP
       2021-10-08 11:24:38 +08:00
    @thtznet 感谢回复,我一直认为领域服务的主要职责是编排自身领域中的实体方法,跨领域调用应该放在 application 层
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   995 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 22:17 · PVG 06:17 · LAX 15:17 · JFK 18:17
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.