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

有实践过领域驱动设计(DDD)的吗?

  •  
  •   dengkj · 2023-06-02 15:44:05 +08:00 · 3835 次点击
    这是一个创建于 539 天前的主题,其中的信息可能已经有所发展或是发生改变。
    37 条回复    2023-06-08 09:43:16 +08:00
    reaganlee1947
        1
    reaganlee1947  
       2023-06-02 15:46:20 +08:00
    公司某绩效系统使用的阿里的 COLA-DDD 框架,但是使用下来感觉 DDD 目前还是不太成熟。可能是我才疏学浅 😭
    fengpan567
        2
    fengpan567  
       2023-06-02 15:48:43 +08:00
    很难搞,必须有个 DDD 专家指导才行,不然每个组都是不同风格的 DDD
    Chad0000
        3
    Chad0000  
       2023-06-02 15:49:18 +08:00 via iPhone
    这个就跟 restful 一样,个人认为不需要照搬。

    我现在设计系统的原则是每个模块完全独立,不要依赖其他模块,然后由流程模块协调所有模块。
    reaganlee1947
        4
    reaganlee1947  
       2023-06-02 15:49:36 +08:00
    @fengpan567 最后开发下来有些同事还是写成了 MVC 谁懂啊
    stiangao
        5
    stiangao  
       2023-06-02 15:56:14 +08:00
    17 年开始接触,到现在实践下来的经验就是,DDD 是一种思想,不是模式,所以直接用别人的框架还不如自己搞,

    确实需要有经验的人来做边界划分
    liylcn
        6
    liylcn  
       2023-06-02 15:59:47 +08:00
    @fengpan567 是的
    而且有个问题,DDD 适用于大规模协作项目,一般公司都没这条件,几个人玩项目很繁琐。。
    dengkj
        7
    dengkj  
    OP
       2023-06-02 16:06:33 +08:00
    看来都觉得 DDD 实践起来比较难,那你们项目一般怎样分层?
    hoopan
        8
    hoopan  
       2023-06-02 16:27:03 +08:00
    刚看的微服务架构设计里,也提到用 DDD 拆分服务,没太看懂。
    yule111222
        9
    yule111222  
       2023-06-02 16:35:58 +08:00
    我已经大规模实践过了,非常香,再回去做非 DDD 的工程很难受
    推荐《解构领域驱动设计》
    ymmud
        10
    ymmud  
       2023-06-02 16:38:05 +08:00
    团队整体水平不行的尽早放弃摆烂
    reaganlee1947
        11
    reaganlee1947  
       2023-06-02 16:38:08 +08:00
    @yule111222 但感觉要把业务逻辑和 CRUD 数据库操作完全脱钩,在现在使用 Mybatis 这些框架的的情况下有点困难。
    yule111222
        12
    yule111222  
       2023-06-02 16:42:17 +08:00
    @reaganlee1947 ORM 框架是个伪 命题,根本不存在。其次,这个只是一个技术基础设施,不论你用什么框架都不会影响领域层的代码。核心业务需要跟技术基础设施完全分离解耦合 再推荐《架构整洁之道》
    DDD 属于上层应用方法论里面对综合要求比较多的,需要深入理解设计原则,整洁架构,面向对象,抽象建模等多种能力,才能较好的落地实现。如果没有这方面的专家还是不要轻易尝试的好,容易适得其反
    TWorldIsNButThis
        13
    TWorldIsNButThis  
       2023-06-02 16:43:48 +08:00 via iPhone

    不过我是先做了一年有点感觉,最近才补理论,以前没做的时候感觉云里雾里的概念现在感觉都很自然,好像本来就应该这样
    TWorldIsNButThis
        14
    TWorldIsNButThis  
       2023-06-02 16:48:17 +08:00 via iPhone
    @reaganlee1947 是这样的
    DDD 是彻底的 IoC ,不是由技术表达业务,而是一切由业务驱动,让技术去实现业务
    Java 语言特性太弱,如果要实现这个目标要写大量的适配代码
    yule111222
        15
    yule111222  
       2023-06-02 16:49:22 +08:00
    @reaganlee1947 任何业务逻辑如果需要优雅的实现更好的复用,都需要更复杂的数据结构来支撑。这本身就跟数据库是脱钩的。为什么 Redis 可以实现那么多数据结构,因为是内存数据库。持久化操作仅仅是内存快照(RDB)和指令日志(AOF)的结合。试想一下,如果你的系统运行在一个内存无限大且不需要持久化到数据库里面的环境中,你会如何进行设计?无论用不用 DDD 推荐的工程架构,纯粹的 OOP 方法本身也不需要考虑持久化。在 DDD 的方法里面这部分工作外包给了 Repository 来完成,这个东西本质上是一个适配器,相当于持久化基础设施与核心之间的桥梁。也可以类比 Linux 的 VFS 系统,为什么 Linux 可以支持那么多文件系统而内核维持在很小的体量,也是类似的方法
    klo424
        16
    klo424  
       2023-06-02 16:54:24 +08:00
    学习了,感谢 OP 开贴。
    sadfQED2
        17
    sadfQED2  
       2023-06-02 16:57:24 +08:00 via Android
    实践过,每个人对 DDD 的理解都不一样。团队整体水平不行的话,尽早摆烂放弃。
    yule111222
        18
    yule111222  
       2023-06-02 17:07:03 +08:00
    为什么面向关系数据库的建模方法不够好呢?
    有如下原因:
    1.二维表难以表达层次结构,出于性能考虑不太可能把一个实体拆分成多张表,这就容易导致复杂的实体表字段非常多认知负担高,且模型难以复用。领域模型通过实体和值对象解决了这个问题
    2.二维表也无法表达继承关系,比如 3 个子类继承于同一个父类,它们可以存储在同一个数据库表里面。从表模型上就看不出继承关系了。领域模型是基于 OOP 的,天然可以表达继承关系
    3.二维表无法对行为和事件建模,难以表达动态性,领域模型里面可以对领域服务和领域事件建模
    4.二维表难以表达关系耦合松紧程度,领域模型通过聚合来约束这个
    dengkj
        19
    dengkj  
    OP
       2023-06-02 17:07:27 +08:00
    @TWorldIsNButThis 语言特性太弱导致要写大量适配代码可以举个例子吗?
    twing37
        20
    twing37  
       2023-06-02 17:09:39 +08:00
    ddd 教给我们一个是从地球看月球,再从月球看地球的多角度看问题的方式.从而让自己的核心代码稳定而非四处修改,这不是准则,也不是银弹.
    dengkj
        21
    dengkj  
    OP
       2023-06-02 17:09:41 +08:00
    @yule111222 方便说一下实践时的团队规模及架构吗
    yule111222
        22
    yule111222  
       2023-06-02 17:10:16 +08:00
    @yule111222 补充一下,实体和值对象本身也有行为,也能表达动态性
    yule111222
        23
    yule111222  
       2023-06-02 17:12:24 +08:00
    @dengkj 技术团队 40 人左右,不过其实和规模无关,和人的能力有关。能力到位了,1 个人也可以用。
    规模更多的是决定了工程架构和服务划分的方式,规模小可以把多个 子领域 放到一个工程里面,通过多模块来切分。
    dengkj
        24
    dengkj  
    OP
       2023-06-02 17:14:03 +08:00
    @yule111222 实践过程中用什么工具(例如 UML 类图)来表达限界上下文以及领域模型?
    yule111222
        25
    yule111222  
       2023-06-02 17:14:46 +08:00
    @dengkj processon
    rozbo
        26
    rozbo  
       2023-06-02 17:17:31 +08:00
    我用 DDD 两年了,总结一下,小项目小团队只要有这个思想就好了,没必要完全做到。。但是如果真的做到了,除了效率低一点,后续的维护真的很香
    dengkj
        27
    dengkj  
    OP
       2023-06-02 17:19:55 +08:00
    @yule111222 团队规模大小只会影响服务划分,工程架构应该都是一致的吧?比如按照用户接口层、应用层、领域层、基础设施层这样。
    dengkj
        28
    dengkj  
    OP
       2023-06-02 17:21:17 +08:00
    @yule111222 ProcessOn 是个好工具,其实我是想问限界上下文通过什么图来描述?
    yule111222
        29
    yule111222  
       2023-06-02 17:24:56 +08:00
    @dengkj 我没找到特别好的工具,但是这个东西比较抽象和简单 processon 也能画的,弄几个椭圆画几根线就行。 工程架构也会影响,多子域放到一个工程里 和 每个子领域一个服务的架构上是有区别的,不过对分层影响是不大。我本人使用的是自创的架构,基于菱形对称架构改造而来的
    reaganlee1947
        30
    reaganlee1947  
       2023-06-02 17:28:13 +08:00
    @dengkj Event storming 能很好的进行领域分析
    @SeAlso: https://www.eventstorming.com/
    dengkj
        32
    dengkj  
    OP
       2023-06-02 17:48:08 +08:00
    @reaganlee1947 谢谢,我参考一下
    dengkj
        33
    dengkj  
    OP
       2023-06-02 17:48:39 +08:00
    @yule111222 好的,谢谢解答,我自己去实践一下
    MadDave
        34
    MadDave  
       2023-06-03 16:08:20 +08:00
    @TWorldIsNButThis Java 是面向对象的语言还弱
    MadDave
        35
    MadDave  
       2023-06-03 16:10:04 +08:00
    @TWorldIsNButThis 这,认真的吗,Java ood 语言还弱
    iRiddle
        36
    iRiddle  
       2023-06-07 17:49:34 +08:00
    我毕业刚入职的时候部门就已经在用 ddd 了,我之前没有任何企业开发经验,导致我一直不太明白 ddd 具体是啥,只是觉得部门那些服务这样设计是理所当然的。。。后来觉得 ddd 本来也没有什么固定或者最优的模式,每个团队的理解都不一样,我们是有一整个架构组和各个小组的资深同事在维护这个架构,谈不上最优不过收益能比投入的成本大就值得使用了
    dengkj
        37
    dengkj  
    OP
       2023-06-08 09:43:16 +08:00
    @iRiddle 羡慕大佬,刚毕业就接触到了 DDD 。就目前的理解来说,DDD 就是一种指导思想,只要把握了分离业务复杂度和技术复杂度这个大方向,具体的架构可以因地制宜。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3307 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 10:38 · PVG 18:38 · LAX 02:38 · JFK 05:38
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.