前言

任何人类的设计都会腐化,软件系统也不例外

腐化之谜

随着系统的规模增长和复杂度膨胀,系统会慢慢腐化。

于是改一个很简单的下单地址,就会牵动整个交易系统十几处的改动。

如何解决这种腐化之谜呢?

参考计算机系统架构:

一个复杂的计算机系统架构包括:软件系统元素,元素之间的联系,元素本身有自己特有属性。

于是我们可以在架构角度参考计算机系统架构的实现。

架构建模

为达到上面提到的架构建模的目的,引入领域驱动。

领域驱动围绕业务概念构建领域模型,通过分离技术的方式实现应对复杂业务,及系统难以演进问题的解决方案。

DDD带来的不同:

  1. 将原有以技术角度审视架构演进的视角,转换到以业务视角切入架构。
  2. 业务复杂度来源于领域本身,深入领域,正确识别出领域深层次概念及关系。
  3. 将领域知识进行结构性表达,同时与编程模型保持一致,便形成了DDD。

基于问题空间的DDD模式

基于解空间的DDD模式

界限上下文

由显示边界限定的特定内聚职责,领域模型便存在于上下文之内。

界限上下文识别过程:

领域分析

如何通过真实业务驱动需求演化出DDD模型呢?

可以采用事件风暴进行领域分析。

流程:

  1. PM,运营,RD共聚一堂
  2. 数小时内理解复杂领域
  3. 标记简单的UML
  4. 工作流程与DDD完美匹配
  5. 事件流演化

以电商系统为例

事件风暴
事件:PM关心真实事件
如:用户订单已发布,商品已发布
说明:关注点在于什么领域模型发生了什么变化。

命令风暴
命令:通过什么活动产生了事件
如:用户提交了订单,开放平台同步商品
说明:命令帮助我们明确系统对外提供的能力,同时明确业务上的输入
命令来源:用户UI界面的操作,外部系统调用触发,定时任务触发

寻找聚合
聚合:一组相关性领域模型的聚合,用来封装业务不变性,确保关联紧密的领域模型内聚在一起
如:订单和商品
聚合的目的在于业务内聚,强迫RD进行简化领域模型的关联,实现业务设计高内聚低耦合的目的

划分界限上下文

  1. 业务模型的问题是否同一个,是则放在同一个界限上下文中
  2. 如果一个聚合同时解决了多个问题,则需要定义不同的上下文确定解决特定问题

界限上下文之内可以自由选择架构模式,如MVC,CQRS,微服务,SOA等。

不是所有界限上下文都采用领域驱动方式,非核心子域可参考数据驱动下的面向过程编程。

提取出面向切面的聚合层,以工程技术因素为主要考虑点。

DDD的核心价值在于指导划分界限上下文。

DDD分层设计

领域模型建设思路:

  1. 业务与技术关注点分离,依赖倒置,内部不依赖于外部且外部可替换
  2. 接口适配器架构
  3. 防腐层建设,领域模型依赖稳定性

参考六边形架构:

架构目标:

  • 独立于框架
  • 与数据库分离
  • 可测试性
  • 与外部结构分离
  • 与UI分离

架构原则:

  • 关注点分离,切割不同层
  • 依赖原则:外部依赖内部,依赖倒置
  • 架构设计围绕用例

结合CQRS设计

CQRS:命令查询职责分离

将更复杂的领域模型拆分为读取和写入两部分。
将消息传递,数据日志同步,领域事件和事件溯源使用到特定上下文。

领域驱动实践

目前我们活动营销系统中,存在大量迭代需求都是针对运营需求所设计,需求本身具有复杂性和持续迭代性,故均已转换采用领域驱动设计方式实现。

对现有及可预期的玩法需求进行了逻辑抽象,提供了统一业务领域玩法模型,为运营提供统一玩法配置管理平台,进行玩法需求配置,经过领域系统内核进行集成,对用户输出统一玩法活动UI及流程。

在局部演进及扩展需求,采用元数据+大字段应对信息的不确定性,流程引擎+规则引擎构造玩法,DSL提供动态创建玩法资源配置的能力。

梳理事件风暴,抽象命令风暴,寻找履行命令的业务名词,对类似的名词玩法进行共性提取,做合适的抽象,同时建立通用语言描述及定义。

采用DDD分层架构+六边形架构+CQRS模型,使得系统具备面向领域驱动的演进能力。

最后

DDD不是银弹

哪些产品适用于DDD:

  1. 是否是复杂问题,或者子域内具有复杂性
  2. 业务是否重要且有很高的预期
  3. 是否可以让运营和PM介入
  4. 遵循迭代式的开放方法

领域模型好坏的标准:

  1. 模型反映了对于问题的抽象,抽象没有统一的标准
  2. 模型是迭代演进的,需要持续集成,改进
  3. 通用语言,领域模型和代码目标意图一致

更多交流:

DDD应对运营活动系统腐化实践的更多相关文章

  1. No zuo no die:DDD 应对具体业务场景,Domain Model 重新设计

    写在前面 上联:no zuo no die why you try 下联:no try no high give me five 横批: let it go上联:no zuo no die why y ...

  2. DDD 应对具体业务场景,Domain Model 重新设计

    DDD 应对具体业务场景,Domain Model 重新设计 写在前面 上联:no zuo no die why you try 下联:no try no high give me five 横批: ...

  3. 升讯威微信营销系统开发实践:(1)功能概要与架构设计( 完整开源于 Github)

    GitHub:https://github.com/iccb1013/Sheng.WeixinConstruction因为个人精力时间有限,不会再对现有代码进行更新维护,不过微信接口比较稳定,经测试至 ...

  4. Zabbix监控系统深度实践

    Zabbix监控系统深度实践(企业级分布式系统自动化运维必选利器,大规模Zabbix集群实战经验技巧总结,由浅入深全面讲解配置.设计.案例和内部原理) 姚仁捷 著  ISBN 978-7-121-24 ...

  5. 升讯威微信营销系统开发实践:订阅号和服务号深入分析( 完整开源于 Github)

    GitHub:https://github.com/iccb1013/Sheng.WeixinConstruction因为个人精力时间有限,不会再对现有代码进行更新维护,不过微信接口比较稳定,经测试至 ...

  6. 京东基于Spark的风控系统架构实践和技术细节

    京东基于Spark的风控系统架构实践和技术细节 时间 2016-06-02 09:36:32  炼数成金 原文  http://www.dataguru.cn/article-9419-1.html ...

  7. 从游击队到正规军(三):基于Go的马蜂窝旅游网分布式IM系统技术实践

    本文由马蜂窝技术团队电商交易基础平台研发工程师"Anti Walker"原创分享. 一.引言 即时通讯(IM)功能对于电商平台来说非常重要,特别是旅游电商. 从商品复杂性来看,一个 ...

  8. 大型网站系统架构实践(五)深入探讨web应用高可用方案

    从上篇文章到这篇文章,中间用了一段时间准备,主要是想把东西讲透,同时希望大家给与一些批评和建议,这样我才能有所进步,也希望喜欢我文章的朋友,给个赞,这样我才能更有激情,呵呵. 由于本篇要写的内容有点多 ...

  9. 升讯威微信营销系统开发实践:(4)源代码结构说明 与 安装部署说明( 完整开源于 Github)

    GitHub:https://github.com/iccb1013/Sheng.WeixinConstruction因为个人精力时间有限,不会再对现有代码进行更新维护,不过微信接口比较稳定,经测试至 ...

随机推荐

  1. Vue的11个生命周期函数的用法

    实例的生命周期函数(官方11个):beforeCreate:在实例部分(事件/生命周期)初始化完成之后调用.created:在完成外部的注入/双向的绑定等的初始化之后调用.beforeMount:在页 ...

  2. Angular应用架构设计-3:Ngrx Store

    这是有关Angular应用架构设计系列文章中的一篇,在这个系列当中,我会结合这近两年中对Angular.Ionic.甚至Vuejs等框架的使用经验,总结在应用设计和开发过程中遇到的问题.和总结的经验, ...

  3. python实现进制转换(二、八、十六进制;十进制)

    python实现进制转换(二.八.十六进制:十进制) (一)十进制整数转为二.八.十六进制 1.format实现转换>>> format(2,"b") # (10 ...

  4. linux 内网时间同步配置

    在工作中,内网环境机器的时间会有所差异,在某些测试环境下需要一毫秒都不允许出现误差,但又不想同步外网时间,那我们可以选择一台机器作为时间服务器来供其他机器进行时间同步,例如每隔1分钟同步一次时间. 一 ...

  5. mysql8.x 新版本jdbc连接方式

    旧版本,MySQL Connector/J 5.x 版本的连接方式:url = jdbc:mysql://localhost:3306/thrcloud_db01?useUnicode=true&am ...

  6. CentOS7清理老旧内核

    CentOS7如果是一步步内核升级上来的将会面临一个问题(一般安装了图形化界面的系统常见),由于内核增多/boot/的容量减少,导致启动变慢.这时就需要清理老旧内核,释放/boot/空间. 使用una ...

  7. mysql开发相关

    1.mysql事务原理,特性,事务并发控制2.如何解决高并发场景下的插入重复3.乐观锁和悲观锁4.常用数据库引擎之间区别5.mysql索引6.B-Tree7.mysql索引类型8.什么时候创建索引9. ...

  8. 《你说对就队》第八次团队作业:Alpha冲刺 第四天

    <你说对就队>第八次团队作业:Alpha冲刺 第四天 项目 内容 这个作业属于哪个课程 [教师博客主页链接] 这个作业的要求在哪里 [作业链接地址] 团队名称 <你说对就队> ...

  9. 行为型模式(五) 中介者模式(Mediator)

    一.动机(Motivate) 为什么要使用中介者模式呢?如果不使用中介者模式的话,各个同事对象将会相互进行引用,如果每个对象都与多个对象进行交互时,将会形成如下图所示的网状结构.从上图可以发现,如果不 ...

  10. [唐胡璐]Selenium技巧 - 利用MonteScreenRecorder录制视频

    我们可以用以下方式在Selenium Webdriver中capture video. 基本步骤: 从 http://www.randelshofer.ch/monte/,下载“MonteScreen ...