10 | DDD、中台和微服务:它们是如何协作的?
10 | DDD、中台和微服务:它们是如何协作的?
讲述:欧创新
时长14:32大小9.97M
DDD 的本质
中台的本质
DDD、中台和微服务的协作模式
中台如何建模?
总结
思考题
赞 30
提建议
精选留言(37)
- 肖大保健2019-11-16我们做的跨境物流下单系统,涉及到用户,商品,支付,订单一些服务,用户,商品,支付相当于通用中台,订单这一块我有点矛盾,不知该归于核心还是通用,订单有,数据流的一些扭转,其他服务都是服务于订单,订单有核心的条件,但是从另外一方面讲,用户增删查改,这些操作订单,感觉也是比较通用型的,我该如何划分出核心中台
作者回复: 订单可能既是通用中台,又是核心中台,个人感觉订单在电商领域偏通用多一些,它就是一个很常见的公共能力中台。其实还是要看企业的战略,订单对电商企业太常见了,应该不会给企业带来太大的核心竞争力吧,除非这种订单模式是跟其它企业不太一样,而这种能力可以给公司带来非常大的优势。划分核心中台要看你的企业核心竞争力是否在这个领域?
共 6 条评论23 - 钱晟龙🐲龍🐉2020-02-22用户管理+用户组织架构管理+认证&鉴权,我们都做到一个微服务里面了~~, 这样看来可以拆3个出来 =。= 不过那样拆得太细的话,程序员写代码快速迭代期,项目来回切换发布,挺痛苦。 前后分离一个repository 一个前端部署, 用户sso单点登录一个api层服务 一个部署, 服务层用一个服务把三种领域包圆了。 老师怎么看这个问题,太细了会不会反而让系统变得维护时间变长。展开
作者回复: 其实在不具备微服务的自动化运维条件的时候,不建议你拆的太细,你可以按照DDD的设计思想,做好微服务内部聚合之间的解耦,等运维条件具备后再拆分。其实这些聚合运行在同样一个微服务内部也是没有关系的,但是你要做好各种依赖的解耦,避免等你想拆的时候因为耦合度过高拆起来困难。
共 3 条评论13 - 若水2019-11-04老师,我想咨询一下,画领域驱动设计图一般用什么样的工具
作者回复: 你说的设计图不知道是指哪类设计图。 DDD似乎还没有什么太好的用于设计的工具,有的话也就是UML之类的工具,很多工具用的也不是特顺手。DDD还缺少一些自动化的代码生成工具以及设计工具,这是它的短板。 我作图一般用visio,费点劲,但是可以自由发挥。
共 4 条评论7 - 张迪2019-11-05对照着图看,感觉中台和微服务没啥区别,感觉中台就是整合了通用微服务
作者回复: 中台是业务概念,很多同类功能的集合。微服务是这些功能的实现。差异还是挺大的。
共 3 条评论6 - 阿玛铭2019-11-05欧老师好,我在搞一个DDD代码目录结构规范。大概做法:1. 列出DDD的术语表 2. 规定resources目录和包目录下的结构。3.拿一个子子域作为示例给出完整的目录结构。 这件事工作量比较小,但我觉得比较有必要,不建立可执行的规范后面代码管理必然走向混乱。还有就是我担心有一些考虑不周到的地方,这块有可以提供的一些参考吗?
作者回复: 后面有一节专门讲代码目录。
共 4 条评论5 - 发飙的蜗牛2020-02-24感觉讲的有点抽象,没有相关经验有些理解不了,DDD讲个人觉得要循序渐进,还没讲到如何使用DDD去落地微服务,就讲到中台微服务之间的关系这些了,跳跃有点大。
作者回复: 中台跟DDD的战略设计比较接近,所以从这个角度出发,就先讲了。后面实战的技术部分跟微服务设计有比较大的相关性。
共 2 条评论3 - Kian.Lee2019-11-04中台的业务模型和 DDD 的领域模型,我个人觉得只是两种设计思想对同一事物的不同描述,两者都是应对复杂软件系统的构建方法论。
作者回复: 是的。 据说阿里中台业务建模时,有些采用的就是DDD的设计方法。
3 - 张子红2021-08-16中台架构本质是企业级服务,例如七牛图片存储,有多少企业需要企业级复用的服务,阿里业务线繁多,在良好设计的前提下,一定程度可以做到,但涉及多个部门的事情谁说了算呢,如果中小型企业,不建议搞中台化,事倍功半。共 1 条评论2
- 独孤九剑2021-07-09终于有了一个完整的微服务与中台架构设计方法论了,“子域”对标“中台”,“限界上下文”对标“微服务”,一针见血!!!感谢欧老师!1
- zygfengyuwuzu2020-10-24这一讲彻底搞明白了DDD,中台和微服务的关系了
作者回复: 很好!
1 - 如水2020-08-29一个领域的服务,还需要分前台与管理后台吗?
作者回复: 微服务的领域层的业务逻辑需要面向前端和基础资源进行解耦,将它们进行分层主要是为了适配和解耦。 适配能力分为主动适配和被动适配。主动适配主要实现外部用户、网页、批处理和自动化测试等对内层业务逻辑访问适配。被动适配主要是实现核心业务逻辑对基础资源访问的适配,比如数据库、缓存、文件系统和消息中间件等。 主动适配主要是通过用户接口层。用户接口层的主要服务形态是Facade接口服务。Facade接口服务分为接口和实现两个部分,完成服务定向。通过assembler组装器,完成DO与DTO数据的转换和组装,完成前端应用与应用层数据的转换和交换。 被动适配主要通过基础层的仓储来实现,领域逻辑面向接口编程,实现依赖倒置。仓储服务包括仓储接口和仓储实现两部分。仓储接口服务可以供应用层或者领域层服务或方法调用。仓储实现服务完成领域对象的持久化或提供数据初始化所需要的PO数据。
1 - 小谢同学2020-02-02请问老师在真实的ddd战略设计实践中,有没有和敏捷方法相结合的情况出现?我发现ddd中也会采用类似用户故事,用户旅程等工具
作者回复: 当然需要的,DDD的战略设计可以跟敏捷更好的结合,具体需要结合企业和团队情况灵活运用。
1 - 大导演2020-01-10老师您好,是否可以从多快好省四个角度,来解释中台或微服务呢,谢谢
作者回复: 中台偏业务多一些,主要考虑复用,微服务这是业务的系统落地,是实现方式,两者还是有差异的。
共 2 条评论1 - 约书亚2019-11-051.其实还是不太清楚如何区分核心域与通用域,支撑域。特别通用的就肯定不是核心域了是么? 2.上篇里一直讲中台要“联通核心业务链路”,那映射到DDD,怎么才算是“联通核心域链路”呢?
作者回复: 中台是企业级的业务建模。DDD主要解决业务建模和微服务设计的问题。联通核心业务链路,需要在前台设计,让所有的业务环节打通。 划分核心域的主要目的是为了战略投入。很多通用的可能也是核心域。
共 4 条评论1 - 杨杰2019-11-05看图上把用户管理、登陆认证、权限管理分成了三个微服务,那是不是说这三个都要对应独立的数据库?
作者回复: 是的。里面实体会不一样。
1 - 朱振光2019-11-05是否中台就对应一个子域?只是看问题的角度不一样,有没有例外?
作者回复: 首先子域是个相对概念,子域可大可小。你需要将中台和子域的维度对齐,这样才会对应。当然会有例外的情况,我这里说的中台主要是业务中台。现在很多中台的概念,比如技术中台、AI中台等,有些地方可能就不好去做对应了。
1 - JSLiuจุ๊บ¹⁸2019-11-04我的理解是中台是解决重复造轮的的方法,而DDD是建设中台的一种方法,比如前几期提到的,DDD领域的划分方法很适合解决中台建设中,中台能力的边界划分。现在有一个问题,DDD对需求分析有什么影响?包含那几方面。
作者回复: 对需求分析还是有些影响的。 在事件风暴的过程中基本上就大概完成了需求分析的部分内容。在需求分析的文档部分也会有些差异,可能不再是那种长篇大论的需求文档了。一个微服务的需求文档可能是以聚合为单位的面向对象的方式。具体可以结合公司的情况,来慢慢适配。
共 2 条评论1 - FIGNT2019-11-04DDD的概念比较抽象,而中台比较具体。我的理解是中台是DDD的具体实践,和微服务直接挂钩。中台的概念和DDD一一对应。中台的概念是从DDD衍生出来的。
作者回复: 可以这么理解。
1 - 剑八2022-07-20中台核心目标是高效复用及适度支持扩展,不仅是架构形态也涉及组织架构,通常会有解决方案及中台团队。解决方案贴合业务做定制,中台沉淀可复用资产。 微服务核心目标是解耦,实现业务职责内聚的业务服务。微服务看的是整体的业务架构如何物理上剥离。 中台可以用微服务来实现,可以由微服务组合,如交易中台本身是电商域中的一个微服务。展开
- 剑八2022-07-17ddd战略设计是划分域,那这个依据是什么? 如果一个新业务,通常是不了解,也没有业界经验可借鉴,此时是不是先战术设计,找实体,形成聚合,限界上下文,最终得到子域