01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图101丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图2
加微信:642945106 发送“赠送”领取赠送精品课程

发数字“2”获取众筹列表
下载APP 

01 | 领域驱动设计:微服务设计为什么要选择DDD?
2019-10-14 欧创新
DDD实战课 进入课程 

你好,我是欧创新。
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图401丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图601丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图701丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图8
讲述:欧创新
时长 14:38 大小 13.41M

我们知道,微服务设计过程中往往会面临边界如何划定的问题,我经常看到项目团队为微服务到底应该拆多小而争得面红耳赤。不同的人会根据自己对微服务的理解而拆分出不同的微服务,于是大家各执一词,谁也说服不了谁,都觉得自己很有道理。

那在实际落地过程中,我也确实见过不少项目在面临这种微服务设计困惑时,是靠拍脑袋硬完成的,上线后运维的压力就可想而知了。那是否有合适的理论或设计方法来指导微服务设计呢?当你看到这一讲的题目时,我想你已经知道答案了。

没错,就是 DDD。那么今天我就给你详细讲解下:“微服务设计为什么要选择领域驱动设计?”

软件架构模式的演进

在进入今天的主题之前,我们先来了解下背景。

我们知道,这些年来随着设备和新技术的发展,软件的架构模式发生了很大的变化。软件架构模式大体来说经历了从单机、集中式到分布式微服务架构三个阶段的演进。随着分布式技术的快速兴起,我们已经进入到了微服务架构时代。
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图9

我们先来分析一下软件架构模式演进的三个阶段。

第一阶段是单机架构:采用面向过程的设计方法,系统包括客户端 UI 层和数据库两层,采用 C/S 架构模式,整个系统围绕数据库驱动设计和开发,并且总是从设计数据库和字段开始。

第二阶段是集中式架构:采用面向对象的设计方法,系统包括业务接入层、业务逻辑层和数据库层,采用经典的三层架构,也有部分应用采用传统的 SOA 架构。这种架构容易使系统变得臃肿,可扩展性和弹性伸缩性差。

第三阶段是分布式微服务架构:随着微服务架构理念的提出,集中式架构正向分布式微服务架构演进。微服务架构可以很好地实现应用之间的解耦,解决单体应用扩展性和弹性伸缩能力不足的问题。

我们知道,在单机和集中式架构时代,系统分析、设计和开发往往是独立、分阶段割裂进行的。

比如,在系统建设过程中,我们经常会看到这样的情形:A 负责提出需求,B 负责需求分析,C 负责系统设计,D 负责代码实现,这样的流程很长,经手的人也很多,很容易导致信息丢失。最后,就很容易导致需求、设计与代码实现的不一致,往往到了软件上线后,我们才发现很多功能并不是自己想要的,或者做出来的功能跟自己提出的需求偏差太大。

而且在单机和集中式架构这两种模式下,软件无法快速响应需求和业务的迅速变化,最终错失发展良机。此时,分布式微服务的出现就有点恰逢其时的意思了。

微服务设计和拆分的困境

那进入微服务架构时代以后,微服务确实也解决了原来采用集中式架构的单体应用的很多问题,比如扩展性、弹性伸缩能力、小规模团队的敏捷开发等等。

但在看到这些好处的同时,微服务实践过程中也产生了不少的争论和疑惑:微服务的粒度应该多大呀?微服务到底应该如何拆分和设计呢?微服务的边界应该在哪里?

可以说,很久以来都没有一套系统的理论和方法可以指导微服务的拆分,包括微服务架构模式的提出者 Martin Fowler 在提出微服务架构的时候,也没有告诉我们究竟应该如何拆分微服务。

于是,在这段较长的时间里,就有不少人对微服务的理解产生了一些曲解。有人认为:“微服务很简单,不过就是把原来一个单体包拆分为多个部署包,或者将原来的单体应用架构替换为一套支持微服务架构的技术框架,就算是微服务了。” 还有人说:“微服务嘛,就是要微要小,拆得越小效果越好。”

但我想,这两年,你在技术圈中一定听说过一些项目因为前期微服务拆分过度,导致项目复杂度过高,无法上线和运维。

综合来看,我认为微服务拆分困境产生的根本原因就是不知道业务或者微服务的边界到底在什么地方。换句话说,确定了业务边界和应用边界,这个困境也就迎刃而解了。

那如何确定,是否有相关理论或知识体系支持呢?在回答这些问题之前,我们先来了解一下领域驱动设计与微服务的前世今生。

2004 年埃里克·埃文斯(Eric Evans)发表了《领域驱动设计》(Domain-Driven Design
–Tackling Complexity in the Heart of Software)这本书,从此领域驱动设计(Domain Driven Design,简称 DDD)诞生。DDD 核心思想是通过领域驱动设计方法定义领域模型,从而确定业务和应用边界,保证业务模型与代码模型的一致性。

但 DDD 提出后在软件开发领域一直都是“雷声大,雨点小”!直到 Martin Fowler 提出微服务架构,DDD 才真正迎来了自己的时代。

有些熟悉 DDD 设计方法的软件工程师在进行微服务设计时,发现可以利用 DDD 设计方法来建立领域模型,划分领域边界,再根据这些领域边界从业务视角来划分微服务边界。而按照 DDD 方法设计出的微服务的业务和应用边界都非常合理,可以很好地实现微服务内部和外部的“高内聚、低耦合”。于是越来越多的人开始把 DDD 作为微服务设计的指导思想。

现在,很多大型互联网企业已经将 DDD 设计方法作为微服务的主流设计方法了。DDD 也从过去“雷声大,雨点小”,开始真正火爆起来。

为什么 DDD 适合微服务?

“众里寻他千百度。蓦然回首,那人却在灯火阑珊处。”在经历了多年的迷茫和争论后,微服务终于寻到了他的心上人。

那 DDD 到底是何方神圣,拥有什么神器呢?

DDD 是一种处理高度复杂领域的设计思想,它试图分离技术实现的复杂性,并围绕业务概念构建领域模型来控制业务的复杂性,以解决软件难以理解,难以演进的问题。DDD 不是架构,而是一种架构设计方法论,它通过边界划分将复杂业务领域简单化,帮我们设计出清晰的领域和应用边界,可以很容易地实现架构演进。

DDD 包括战略设计和战术设计两部分。

战略设计主要从业务视角出发,建立业务领域模型,划分领域边界,建立通用语言的限界上下文,限界上下文可以作为微服务设计的参考边界。

战术设计则从技术视角出发,侧重于领域模型的技术实现,完成软件开发和落地,包括:聚合根、实体、值对象、领域服务、应用服务和资源库等代码逻辑的设计和实现。

我们不妨来看看 DDD 是如何进行战略设计的。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图10DDD 战略设计会建立领域模型,领域模型可以用于指导微服务的设计和拆分。事件风暴是建立领域模型的主要方法,它是一个从发散到收敛的过程。它通常采用用例分析、场景分析和用户旅程分析,尽可能全面不遗漏地分解业务领域,并梳理领域对象之间的关系,这是一个发散的过程。事件风暴过程会产生很多的实体、命令、事件等领域对象,我们将这些领域对象从不同的维度进行聚类,形成如聚合、限界上下文等边界,建立领域模型,这就是一个收敛的过程。

我们可以用三步来划定领域模型和微服务的边界。

第一步:在事件风暴中梳理业务过程中的用户操作、事件以及外部依赖关系等,根据这些要素梳理出领域实体等领域对象。

第二步:根据领域实体之间的业务关联性,将业务紧密相关的实体进行组合形成聚合,同时确定聚合中的聚合根、值对象和实体。在这个图里,聚合之间的边界是第一层边界,它们在同一个微服务实例中运行,这个边界是逻辑边界,所以用虚线表示。
第三步:根据业务及语义边界等因素,将一个或者多个聚合划定在一个限界上下文内,形成领域模型。在这个图里,限界上下文之间的边界是第二层边界,这一层边界可能就是未来微服务的边界,不同限界上下文内的领域逻辑被隔离在不同的微服务实例中运行,物理上相互隔离,所以是物理边界,边界之间用实线来表示。

有了这两层边界,微服务的设计就不是什么难事了。

在战略设计中我们建立了领域模型,划定了业务领域的边界,建立了通用语言和限界上下 文,确定了领域模型中各个领域对象的关系。到这儿,业务端领域模型的设计工作基本就完成了,这个过程同时也基本确定了应用端的微服务边界。

在从业务模型向微服务落地的过程中,也就是从战略设计向战术设计的实施过程中,我们会将领域模型中的领域对象与代码模型中的代码对象建立映射关系,将业务架构和系统架构进行绑定。当我们去响应业务变化调整业务架构和领域模型时,系统架构也会同时发生调整, 并同步建立新的映射关系。

DDD 与微服务的关系

有了上面的讲解,现在我们不妨再次总结下 DDD 与微服务的关系。

DDD 是一种架构设计方法,微服务是一种架构风格,两者从本质上都是为了追求高响应
力,而从业务视角去分离应用系统建设复杂度的手段。两者都强调从业务出发,其核心要义是强调根据业务发展,合理划分领域边界,持续调整现有架构,优化现有代码,以保持架构和代码的生命力,也就是我们常说的演进式架构。

DDD 主要关注:从业务领域视角划分领域边界,构建通用语言进行高效沟通,通过业务抽象,建立领域模型,维持业务和代码的逻辑一致性。

微服务主要关注:运行时的进程间通信、容错和故障隔离,实现去中心化数据管理和去中心化服务治理,关注微服务的独立开发、测试、构建和部署。

总结

今天我们主要讨论了微服务设计和拆分的难题。通过 DDD 战略设计可以建立领域模型,划定领域边界,解决微服务设计过程中,边界难以划定的难题。如果你的业务焦点在领域和领域逻辑,那么你就可以选择 DDD 作为微服务的设计方法!
更关键的一点是,DDD 不仅可以用于微服务设计,还可以很好地应用于企业中台的设计。如果你的企业正在做中台转型,DDD 将会是一把利器,它可以帮你建立一个非常好的企业级中台业务模型。有关这点你还会在后面的文章中见到详解。

除此之外,DDD 战术设计对设计和开发人员的要求相对较高,实现起来相对复杂。不同企业的研发管理能力和个人开发水平可能会存在差异。尤其对于传统企业而言,在战术设计落地的过程中,可能会存在一定挑战和困难,我建议你和你的公司如果有这方面的想法,就一定要谨慎评估自己的能力,选择最合适的方法落地 DDD。

也不妨根据收获权衡一下,总体来说,DDD 可以给你带来以下收获:

  1. DDD 是一套完整而系统的设计方法,它能带给你从战略设计到战术设计的标准设计过程,使得你的设计思路能够更加清晰,设计过程更加规范。
  2. DDD 善于处理与领域相关的拥有高复杂度业务的产品开发,通过它可以建立一个核心而稳定的领域模型,有利于领域知识的传递与传承。
  3. DDD 强调团队与领域专家的合作,能够帮助你的团队建立一个沟通良好的氛围,构建一致的架构体系。
  4. DDD 的设计思想、原则与模式有助于提高你的架构设计能力。
  5. 无论是在新项目中设计微服务,还是将系统从单体架构演进到微服务,都可以遵循

DDD 的架构原则。

  1. DDD 不仅适用于微服务,也适用于传统的单体应用。

思考题

你的公司是否在实施微服务架构,你在微服务设计过程中面临的最大问题是什么?

欢迎留言和我分享你的思考和疑惑,你也可以把今天所学分享给身边的朋友,邀请他加入探讨,共同进步。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图11

© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。

上一篇 开篇词 | 学好了DDD,你能做什么?
下一篇 02 | 领域、子域、核心域、通用域和支撑域:傻傻分不清?

精选留言 **(47)
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图1201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图13
 写留言
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图14
Geek_a91670 **置 顶
2019-10-21
事件风暴到底是什么啊?
展开

作者回复: 后面章节会有一章专门讲,会有一个案例。跟头脑风暴类似,通过它设计领域模型。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图1501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图16

1
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图17

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图18

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图19halweg
2019-10-14
我能说我等极客时间出这个等了1年吗?
展开
编辑回复: 忠实老粉了啊~期待你的打卡!

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图2001丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图21
4  18

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图2201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图23TH
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图24

2019-10-15
DDD是针对业务的,那么到底怎么理解“业务”呢?什么属于业务,什么不属于业务呢? 尤其是业务与技术、基础设施、中间件之间的关系怎么划分?

换句话说,DDD是否适合技术框架、技术平台甚至技术中台的建设呢?比如我要开发一个代码部署系统或者配置管理系统,这样的系统是否适用DDD呢?因为对整个公司来说它… 展开

作者回复: DDD包括战略设计和战术设计,战略设计主要面向业务完成领域建模,战术设计是根据领域模型完成微服务设计的过程。领域的概念应该包括您所说的代码部署系统或者配置管理系
统,只要能在这些领域中能够提炼出领域模型就可以。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图2501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图26
2  3

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图2701丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图28Randy Liu
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图29

2019-10-21
关于两层边界,聚合虚边界,限界物理实边界,很有启发,也给我一直困惑的,如果一个业务领域中,有多个聚合根的情形下,更加清晰与更好的理解。
展开

作者回复: 边界清晰了,以后微服务的演进就相对简单。一般来说聚合内部的功能都是核心的领域逻辑,是一些相对原子化的业务功能,受外部影响比较小。所以在微服务演进时可以以聚合为单元来进行微服务重组。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图3001丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图31
 1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图3201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图33咸鱼大翻身
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图34

2019-10-20
公司最近也在准备对已有的业务拆分业务领域,希望作者能早点讲实战,对于这块特别是事件风暴方法

作者回复: 很快就到了,耐心等待哈。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图3501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图36

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图37 1
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图38

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图39斯图尔特
2019-10-15
这里提到的业务人员是指?还有领域专家。套用公司场景,一个做企业服务,tob的公司, 有自己的产品。这个过程中,有客户的需求,有项目经理的梳理客户需求。有产品经理对系统的规划,有客户成功提交的使用优化。这个过程中参与人,客户,项目经理,产品经理,客户成功。人员参与,那这些人在DDD领域模型的角色是?
展开

作者回复: 斯图尔特,你好。
领域模型里面都是一些领域对象,这些领域对象是构成系统的一些业务行为。你说的这些角色不知道是不是指系统建设过程中的角色。其实DDD并不改变原来软件开发过程中的角色,只是工作模式发生了变化,大家一起设计领域模型,设计微服务。领域专家是熟悉并深刻理解这个领域的人,可能是业务人员,也可能会是产品经理,甚至可能是开发人员。传统企业一般有信息和业务一说。业务人员一般是指业务部门的人员。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图4001丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图41
 1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图4201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图43酆友鹏
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图44

2019-10-14
听说过,一直不知道怎么去实践DDD
展开

作者回复: 专栏里面会有详细的过程介绍,先理解概念,然后学会怎么用事件风暴建立领域模型, 根据领域模型来设计微服务。等着后面的实战篇哈。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图4501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图46
 1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图4701丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图48Leiy
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图49

2019-10-14
在开始微服务拆分的过程中,碰到两个问题: 1.项目组开发人员对业务的理解不同,对于有些聚合是放在哪个限界上下文中会产生分歧
2.对于一个庞大古老系统,拆分是开始时候就拆分的较细,还是先拆分两个核心业务域, 后面再逐步拆分
展开

作者回复: 很多的时候领域的细分会根据业务流程阶段或者模块功能,这两个方面业务有很好的内聚性,很可能就对应到了子域。如果领域实在太大,你可以考虑将它分成小的领域,然后在这小
的领域中去做事件风暴,划分限界上下文,并确定哪些聚合放在哪个限界上下文里,这里领域专家会起到比较大的作用。不过建立领域模型后,你还需要看看其它子域是否有重叠的内容,如果有的话,还需要对领域模型重组。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图5001丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图51
1  1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图5201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图53方堃
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图54

2019-10-14
我觉得微服务现在转型有个挺大的问题就是团队认识深度。因为现在好多项目都是先简单的以单机项目为基础开发,追求上线速度。后续发现项目越来越大才考虑进行架构方向的整理。导致很有可能出现早期只有开发产品没有架构师参与。这时候转型,架构师多久能吃透现有的业务就是转型速度的瓶颈了。毕竟产品不了解代码,开发人员又往往只盯着自己的模块缺少整体的了解
展开

作者回复: 您说的这些问题确实很常见,很多企业都是业务的归业务,技术的归技术。DDD其实也跟中台建设一样,也是一种企业和组织文化的变化,需要业务和技术融合在一起。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图5501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图56
1  1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图5701丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图58瓜瓜
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图59

2019-10-14
如何用DDD解决复杂业务的架构问题,一直在等这方面的相关课题

作者回复: 希望能对你有帮助。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图6001丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图61
 1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图6201丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图63素丶
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图64

2019-10-14
同等一年
展开

编辑回复: 姗姗来迟~莫怪莫怪!

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图6501丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图66
 1

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图6701丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图68白开水有三种味道
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图69

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图702019-10-21
不是技术人员听的有些干涩,如值,跟,聚合,再讲这些技术名词时如果能配合着案例讲就更好了

作者回复: 后面会有详细案例介绍的。还有专门的中台和微服务设计案例介绍,请耐心等待。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图7101丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图72

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图7301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图74探索无止境
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图75

2019-10-21
好抽象,就是感觉有案例支撑理论会更好,更利于阅读下去

作者回复: 后面会有案例介绍,敬请等待。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图7601丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图77

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图7801丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图79切糕
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图80

2019-10-20
目前我们公司的一款产品正在做微服务的拆分。之前听说过DDD,一直没有完整的概念。期待老师的课程。

作者回复: 希望能够帮助到你。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图8101丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图82

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图8301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图84like_jun
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图85

2019-10-19
正在用DDD设计进行项目重构
展开

作者回复: 希望能对你有帮助。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图8601丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图87

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图8801丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图89墨名次
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图90

2019-10-19
学完第一章,回想之前在项目中遇到一些不明白的问题瞬间豁然开朗,对服务拆分的理解又深了一些,但是对一些词还比较难理解,比如“事件风暴,根聚合”之类的,很期待老
师后面的课程

作者回复: 这些后面都会讲到,敬请期待。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图9101丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图92

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图9301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图94骨汤鸡蛋面
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图95

2019-10-17
从老师的表述,是否可以理解为:ddd是一个事件风暴 ==> 分类划分,进而知道组织划分
(也就是中台)、系统划分(微服务)、代码划分/设计的思想方法
展开

作者回复: 是这样的。后面会有设计过程的详细介绍。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图9601丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图97

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图9801丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图99肖大保健
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图100

2019-10-16
目前公司用的是spring boot 框架,根据业务也做了明显得服务拆分(接单web,调度服务,订单服务,用户服务,资金服务,api服务 等),后期打算把数据层(mysql,mong
o,redis)单独拆分出去,web层controller再单独拆分做HA 或者 ng,不知道算不算的上微服务架构,我们在做服务拆分,功能聚合这块是按业务模块来的
问题一:服务的功能界限该如何划定(按功能,还是按业务,有点矛盾)…
展开

作者回复: 你说的这几个问题我后面都会讲到,耐心等待哈。第一个问题:会通过事件风暴来建立领域模型。
第二个问题:前后端分离后,可通过API网关调用后端微服务,或者对于复杂的业务场景可以考虑在前端与后端微服务之间增加一个BFF的微服务,可以对多个微服务进行服务组合和编排。
第三个问题:限界上下文边界理论上就是微服务的边界。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图10101丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图102

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图10301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图104Geek_e08323
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图105

2019-10-16
今年开始接触DDD,公司也是准备使用DDD设计方法来搞微服务,因为我们公司的3层架构的项目都很适合使用DDD。看了领域驱动设计的书籍,理解起来很困难,没有具体的案例作为参考,落地困难。
作者回复: 希望这个专栏对你有帮助,进阶篇和实战篇里有比较详细的介绍。

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图10601丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图107

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图10801丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图109Jxin
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图110

2019-10-16
1.一年前学的ddd,半年前学的重构,现如今项目从架构到核心业务都重构了。这个专栏, 实在等了太久。

2.目前公司采用了微服务组件和框架。但绝对不是微服务,缺少合理的业务拆分,缺少对应的敏捷开发基建(没有cicd,没有测试用例,没有自动化回归测试,没有完善的监控平… 展开

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图111作者回复: 微服务不只是微服务的事情。微服务的出现也不是偶然出现的,是技术和研发模式积累到一定阶段后才出现的。底层它与云计算平台、CICD、Devops等是离不开的,在研发模式上与敏捷也是关联非常紧密的。所以微服务的建设需要很多的积累,这些积累不够的话,对于企业级的微服务将会是很难的。
01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图112

01丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图11301丨领域驱动设计:微服务设计为什么要选择DDD?【海量资源:todo1024.com】 - 图114