点击关注下方公众号,架构师全套资料 都在这里

0、2T架构师学习资料干货分享

作者:等不到的口琴
链接:www.cnblogs.com/Courage129/p/14839544.html

上一篇:小红书,又涉黄了!网友:干脆改名小黄书吧~

DDD为什么能火起来?

我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景, 根据我学习的套路, 永远是为什么为先,再是解决什么问题,是什么东西, 最后如何使用。

我们都知道这些年随着设备以及技术的发展,软件架构发生了很多变化,从最初的单机(BS/CS)架构到后面的集中式架构,再到如今的微服务架构, 现在基本可以说是微服务架构盛行的时代, DDD早在2004年就由埃里克·埃文斯提出, 但一直处于一个不愠不火的状态,直到Martin Fowler的《Microservices》引起大家注意, 也就是微服务盛行之后(这儿需要说明的是,微服务最早的提出者不是Martin Fowler,而是Fred George), DDD再次回到人们视野中间,为什么呢 ?

我们先看一下三种技术架构的演进以及主要区别:

第一阶段是单机架构,特征是整个开发围绕着数据库进行设计和开发。

第二个阶段是三层式的集中式架构,采用面向对象的设计方法,业务逻辑分业务层、逻辑层、数据访问层,这种架构很容易某一层或者几层变得臃肿,扩展性较差, 另外摩尔定律失效, 单台机器性能有限。

第三层阶段是微服务架构,在集中式架构中, 系统分析、设计和开发往往是独立进行的,而且各个阶段负责人可能不一样,那么就涉及到交流信息丢失的问题, 另外项目从分析到开发经历的流程很长,很容易最终开发设计与需求实现的不一样,微服务主要就是解决第二阶段的这些痛点,实现应用之间的解耦,解决单体应用扩展性的问题。

微服务存在的问题

进入微服务之后 , 解决了集中式架构的单体应用很多问题, 但是新的问题应运而生 , 微服务的粒度应该多大 ?微服务如何设计呢?微服务如何拆分 ?微服务边界在哪里 ?

很长时间人们都没有解决这一问题,就连Martin Fowler在提出微服务架构的时候也没有告诉我们这该如何拆分微服务。

甚至在很长的时间里人们对微服务拆分产生了一些误解, 有人认为:"微服务很简单,就是将之前的单体应用拆分成多个部署包, 或者将原来的单体应用架构替换为一套支持微服务的技术架构,就算是微服务了。" 还有人认为微服务应该拆分得越小越好。

鉴于上述情形, 很多项目因为前期拆分过度, 导致复杂度过高, 导致后期难以运维甚至难以上线。另外,微服务系列面试题和答案全部整理好了,微信搜索互联网架构师,在后台发送:2T,可以在线阅读。

可以得出一个结论:微服务拆分困境产生的根本原因就是不知道业务或者微服务的边界到底在什么地方。换句话说,确定了业务边界和应用边界,这个困境也就迎刃而解了。

而DDD就是解决了这个确定业务边界的问题,可见DDD并不是一种技术架构,而是一种划分业务领域范围的方法论。DDD的兴起是由于很多熟悉领域驱动建模(DDD)的工程师在进行微服务设计时, 发现用DDD的思路进行业务梳理可以很好规划服务边界, 可以很好实现微服务内部和外部的"高内聚、低耦合"。于是越来越多的人将DDD作为业务划分的指导思想。

那么,什么是DDD呢?

DDD概述

通过上文的学习就可以知道DDD是一种拆解业务、划分业务、确定业务边界的方法, 是一种高度复杂的领域设计思想,将我们的问题拆分成一个个的域, 试图分离技术实现的复杂性,主要解决的是软件难以理解难以演进的问题,DDD不是一种架构, 而是一种架构方法论, 目的就是将复杂问题领域简单化, 帮助我们设计出清晰的领域和边界, 可以很好的实现技术架构的演进。DDD包括两部分,战略设计部分 和 战术设计部分

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

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

DDD战略设计会建立领域模型, 这四个字放一起会让人觉得很高深, 其实是纸老虎, 通俗来说就是模拟某个领域的的一种模型, 这个模型比较抽象, 但便于人们交流, 举个例子:公园有一棵桃树, 如果我们想好好研究桃树该怎么研究 ?

桃子好吃吗?贵不贵?品种?怎么种植?种在什么地方 ?做成桃木剑?桃子树叶药用价值?

你看, 这样研究每一个问题都很有道理, 但是又很混乱,再回忆一下初中生物书上是这么研究的?,微信搜索公众号互联网架构师,在后台发送:2T,送你一份惊喜礼包。

先将植物根据大家的理解分成多个器官组成, 像桃子、桃叶、桃花等等, 然后将每一个器官再根据功能细分成组织, 再根据这个组织中各个细胞的形态等作用分成不同的细胞, 你看看这是不是一种很有条理的分析方法。

DDD也是如此, 当我们面对桃树这种复杂的业务的时候,先根据固有的认识分成多个器官(领域),然后再在每一个领域中根据某些维度(这儿是功能)分为多个组织(聚合), 而每一个组织中由很多细胞(实体)组成,这就是一种战略, 有哪些好处呢 ?

可以确保我们讨论的边界, 也就是讨论的东西是一个领域一个维度的, 对于桃树来说, 桃子 、桃花、桃叶、树干都是不同的领域, 划分不同领域的就是边界, 我们这儿叫领域边界, 当我们确定好这些领域之后, 就可以确保我们讨论的是同一个领域部分的东西,这样的好处就是我们可以规定好一些概念, 或者说术语, 以后大家讨论的时候就尽可能少的信息丢失。

DDD战略设计会建立领域模型 , 领域模型用来指导微服务的设计和拆分, DDD第一步要做的就是来一个头脑风暴, 可以理解成一起讨论对业务的理解 , 主要目的就是尽可能前面不遗漏的分解我们的业务领域, 就好比刚刚的桃树, 最先要做的就是尽可能多的分析, 确保每一个领域都可以被关注到。

在实践中 ,往往会采用用例分析、场景分析和用户旅程分析, 这是一个发散的过程,头脑风暴阶段会产生很多实体、命令、事件等领域对象, 我们从不同的维度对进行聚类形成聚合、限界上下文等边界,建立领域模型, 这是一个收敛的过程。

具体来说, 我们可以通过三步来确定领域模型和微服务边界。

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

第二步:根据领域实体之间的业务关联性,将业务紧密相关的实体进行组合形成聚合,同时确定聚合中的聚合根、值对象和实体。在这个图里,聚合之间的边界是第一层边界,它们在同一个微服务实例中运行,这个边界是逻辑边界,所以用虚线表示。微信搜索公众号互联网架构师,在后台发送:2T,送你一份惊喜礼包。

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

上面除了领域、聚合、实体外还出现了聚合根、值对象等词语, 除此之外还有统一建模语言、子域、核心域、通用域、支撑域等, 其实都是纸老虎, 前面说过了为了方便对于某个领域的讨论往往会形成一些概念,这些概念会有一些名词概括, 上面的名词就是这么来的, 这就叫统一建模语言 , 哈哈哈 ,好了,不扯淡, 我后面的文章会解释下这些词语的意思, 这儿主要讨论DDD解决什么了问题。

梳理一下DDD与微服务的关系, DDD 是一种架构设计方法,微服务是一种架构风格,两者从本质上都是为了追求高响应力,而从业务视角去分离应用系统建设复杂度的手段。两者都强调从业务出发,其核心要义是强调根据业务发展,合理划分领域边界,持续调整现有架构,优化现有代码,以保持架构 和代码的生命力,也就是我们常说的演进式架构。DDD 主要关注:从业务领域视角划分领域边界,构建通用语言进行高效沟通,通过业务抽象,建立领域模型,维持业务和代码的逻辑一致性。微服务主要关

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

总结

这篇文章主要研讨了DDD火起来的原因, 解决了什么业界难题, 知道DDD主要思路 , 以及DDD大概的实现步骤等 。

留个小问题:单体应用适合DDD吗?

DDD为什么能火起来?和微服务有啥关系?相关推荐

  1. DDD(领域驱动设计)系列主题:DDD兴起的原因以及与微服务的关系

    目录 DDD为什么能火起来? 微服务存在的问题 DDD概述 总结 DDD为什么能火起来? 我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景, 根据我学习的套路, 永远是为什么为先,再是解决什么 ...

  2. java跟微服务什么关系_分布式和微服务是什么关系?

    分布式和微服务是什么关系?简单来说,分布式和微服务的概念比较相似,分布式属于微服务.但是分布式和微服务在架构.作用和粒度上有所区别.因此,两者的关系是既相互联系又相互区别.本文主要带大家认识分布式和微 ...

  3. 服务化架构、SOA、微服务是什么关系

    服务化架构.SOA.微服务是什么关系 小结:服务化架构是宏观目标,SOA与微服务架构是落地实现.服务化架构-强调对业务垂直拆分形成多个服务模块.然而分布式子系统没有标准,需要一个平台例如ESB,提供中 ...

  4. DDD 为什么能火起来?和微服务有啥关系?

    点击上方"Java精选",选择"设为星标" 别问别人为什么,多问自己凭什么! 下方有惊喜,留言必回,有问必答! 每天 08:35 更新文章,每天进步一点点... ...

  5. 当中台遇上DDD,我们该如何设计微服务?

    微服务架构有哪些模型?中台.领域驱动设计及微服务之间有着什么样的关系?微服务的边界设计怎么做?怎么做设计和拆分?且看作者为你娓娓道来. 借用当下最流行的段子做个开场白. "设计原则千万条,高 ...

  6. DDD 兴起的原因以及与微服务的关系

    点击关注公众号,回复"1024"获取2TB学习资源! DDD为什么能火起来? 我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景,根据我学习的套路,永远是为什么为先,再是解决 ...

  7. 阿里技术员:DDD兴起的原因以及与微服务的关系

    DDD为什么能火起来? 我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景, 根据我学习的套路, 永远是为什么为先,再是解决什么问题,是什么东西, 最后如何使用.我们都知道这些年随着设备以及技术 ...

  8. 从架构演进谈 DDD 兴起的原因以及与微服务的关系

    -     前言     -  DDD为什么能火起来? 我们先不讨论DDD的定义, 先梳理一下DDD火起来的背景, 根据我学习的套路, 永远是为什么为先,再是解决什么问题,是什么东西, 最后如何使用. ...

  9. springcloud 整合 gateway_GitHub上最火的SpringCloud微服务商城系统项目,附全套教程

    项目介绍 mall-swarm是一套微服务商城系统,采用了 Spring Cloud Greenwich.Spring Boot 2.MyBatis.Docker.Elasticsearch等核心技术 ...

最新文章

  1. 重磅:国拨概算5.34亿!“新一代人工智能”重大项目项目申报指南发布
  2. 2019春季学期进度报告(十六)
  3. loj2538 「PKUWC2018」Slay the Spire 【dp】
  4. sonarqube执行命令遇上的小问题
  5. Angular(build打包)报错:supplied parameters do not match any signature of call target
  6. 现代软件工程讲义 9 测试 QA 的角色和分工
  7. directsound抓取麦克风PCM数据封装类
  8. SpringMVC 框架系列之组件概述与配置详解
  9. Vue自定义指令—— 完美解决H5页面不同尺寸屏幕的适配问题
  10. 在Debian 6 安装pptpd ×××。
  11. Mysql索引会失效的几种情况
  12. pop,oop,aop编程思想
  13. 通达+oa+php+文件+乱,通达OA文件上传+文件包含get shell复现
  14. 8位可控加减法电路设计
  15. 怎么在WPS计算机,电脑怎么把wps热点删了?电脑永久删除wps热点的方法
  16. 学习OpenCV3:在空白图片上画虚线
  17. Linux Socket编程
  18. 3GPP协议 25.105
  19. [UE5 C++] 免费安装JetBrains Mono字体至IDE
  20. 【微信小程序】不支持使用本地图片设置背景图片解决方法

热门文章

  1. httpCanary app抓包
  2. 农夫过河问题(图结构)
  3. arcgis图斑尖角检查_ArcGIS消除零碎图斑(Eliminate)
  4. 金融计量模型(六):金融时间序列及其特征
  5. 安装 Windows Server 2019 VM虚拟机
  6. 等号(=),双等号(==)还有三等号(===)的使用与区别
  7. 批量制作的标签如何选择打印范围
  8. 安装Android应用至SD卡
  9. swift版QQ音乐播放器(一)
  10. GEE|时间序列分析(三)