作者回复: 后面章节会有一章专门讲,会有一个案例。跟头脑风暴类似,通过它设计领域模型。
编辑回复: 忠实老粉了啊~期待你的打卡!
作者回复: 👍高手,每节的总结可以交给你来做了😀。
作者回复: 第一个问题,我想知道不同工厂软件需求的差异主要在什么地方?如果差异在流程和服务编排,DDD的分层架构应用服务很合适。如果领域层业务逻辑差异不大的话,就比较好解决。个人感觉领域层的核心逻辑差异应该不会大。
第二个问题,DDD数据库方面采用依赖倒置的方式,实现业务逻辑的时候,不会有数据库方面的逻辑,都是领域对象的行为,数据库相关代码在仓储实现中实现。也就是说业务实现与数据库是松耦合的,换数据库的时候,只需要换仓储逻辑就可以了,不会影响核心业务逻辑。
第三方问题,你说的这几个子域相对清晰,直接在子域做事件风暴,建立领域模型,设计微服务就可以了。
第四个问题,见以上三条。总之,保持领域层领域模型的稳定,用应用层去适配外部需求的变化,用户接口层面向不同渠道提供个性数据服务。
作者回复: DDD包括战略设计和战术设计,战略设计主要面向业务完成领域建模,战术设计是根据领域模型完成微服务设计的过程。领域的概念应该包括您所说的代码部署系统或者配置管理系统,只要能在这些领域中能够提炼出领域模型就可以。
作者回复: 选了一个企业级的中台设计,从领域建模到微服务设计选取了几个典型的中台,过程基本是完整的。最后的示例,源代码只到服务和实体类级别,里面具体业务实现代码没有。也就是说微服务整体架构的框架搭起来,但没有往里填肉。
作者回复: 斯图尔特,你好。
领域模型里面都是一些领域对象,这些领域对象是构成系统的一些业务行为。你说的这些角色不知道是不是指系统建设过程中的角色。其实DDD并不改变原来软件开发过程中的角色,只是工作模式发生了变化,大家一起设计领域模型,设计微服务。领域专家是熟悉并深刻理解这个领域的人,可能是业务人员,也可能会是产品经理,甚至可能是开发人员。传统企业一般有信息和业务一说。业务人员一般是指业务部门的人员。
作者回复: 您说的这些问题确实很常见,很多企业都是业务的归业务,技术的归技术。DDD其实也跟中台建设一样,也是一种企业和组织文化的变化,需要业务和技术融合在一起。
作者回复: 其实你说的这种现象很普遍,很多企业都是业务的归业务,技术的归技术。不容易融合,这也是很多技术难以推行的原因。
作者回复: 边界清晰了,以后微服务的演进就相对简单。一般来说聚合内部的功能都是核心的领域逻辑,是一些相对原子化的业务功能,受外部影响比较小。所以在微服务演进时可以以聚合为单元来进行微服务重组。
作者回复: 你说的这几个问题我后面都会讲到,耐心等待哈。
第一个问题:会通过事件风暴来建立领域模型。
第二个问题:前后端分离后,可通过API网关调用后端微服务,或者对于复杂的业务场景可以考虑在前端与后端微服务之间增加一个BFF的微服务,可以对多个微服务进行服务组合和编排。
第三个问题:限界上下文边界理论上就是微服务的边界。
作者回复: 你好,刘晓帆。事件风暴对于初创系统的建设是非常合适的。通过事件风暴项目团队可以将所有的可能考虑到,这比一个人思考肯定会更全面更能统一思想。在领域建模和微服务设计时基于现状和不远的将来设计就可以了,但在微服务设计时一定要架构演进的可能,这种架构演进可以很快适应将来的业务发展。如何架构演进,我认为关键在于聚合以及代码边界的设计,在进行功能演进时可以很容易的解耦和进行代码的分离。
作者回复: 很多企业刚开始转型微服务的时候可能都有一个这样的过程。由于没有方法指导,还是在按照传统三层架构的模式做微服务,结果只是换了一套支持微服务的技术框架而已。DDD它是一个知识体系,就像一杯好茶,慢慢品,你就能品出其中的味道来。
作者回复: 您说的第一个问题,尤其是数据代码类应用场景下都是存在的,这种情况下需要考虑必要的数据冗余,可以采用小表广播的方式,源端数据变了后,可以考虑异步方式广播到数据使用的目的端。
第二个拆分需要考虑限界上下文,并且保证业务的高内聚,高内聚你可以理解为原来的模块的概念,具体大小根据你的业务来定。
作者回复: 非常赞同!
作者回复: 是的,单体向微服务架构演进过程中的数据拆分是难点。如果边界清晰就相对容易很多。
作者回复: 第一个问题,不清楚是设计的问题还是消息中间件组件选择的问题。
第二个问题,数据库之间的同步可以采用两种方式,第一种定时扫描源端数据库获取增量数据,但是这种方式会增加数据库的负担和需要单独编写取数代码逻辑。第二种是采用数据库日志捕获技术CDC,但是不知道你这种数据库是否有CDC,如果没有,就不太方便了。
第三个问题,不知道你的报表数据来源,如果是多个微服务,那建议你做一个数据平台,用于汇集各个微服务数据库的数据,所有的报表从这个数据平台获取。
作者回复: 很快就到了,耐心等待哈。
作者回复: 一起学习和进步哈。
作者回复: 专栏里面会有详细的过程介绍,先理解概念,然后学会怎么用事件风暴建立领域模型,根据领域模型来设计微服务。等着后面的实战篇哈。