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

2021-09-30 11:35:07 +08:00
 that24

大佬们好,在落地 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();
    } 
    

期待你的回复~

1869 次点击
所在节点    Java
2 条回复
thtznet
2021-09-30 11:54:11 +08:00
物理世界中的业务映射成领域,领域与领域(跨领域)的逻辑交互通过领域服务,应用服务上接表现层的命令,判断所需的领域服务并调用。
that24
2021-10-08 11:24:38 +08:00
@thtznet 感谢回复,我一直认为领域服务的主要职责是编排自身领域中的实体方法,跨领域调用应该放在 application 层

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/805368

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX