从DDD开始说起
前言
从13年接触DDD之后开始做应用架构已经整整四个年头.
四年里关于DDD的感触良多,慢慢有了一些心得.
关于DDD的介绍已经有很多的文章和书籍,这里我推荐三本最重要的书籍.
《领域驱动设计-软件核心复杂性应对之道》(DDD)
《实现领域驱动设计》(IDDD)
《领域驱动设计模式,原理与实践》(PPPDDD)
具体的DDD介绍这三本书已经很清楚了,但是学完这些之后我认为DDD才刚刚开始.
DDD给我更多的是一种设计启发,无论是里面的战术设计,还是战略设计都可以展开到很多点.
书籍里面很多时候只是一些设计原则,和一些简单的demo,但是基于这些原则作为出发点,可以展开很多的设计.
架构有时候就是一个生长的,当我基于DDD为起点,不断演进架构.这时候架构仿佛也有了生命力,不断地成长,到最后可能是最开始完全想想不到的样子,我想这大概就是架构的魅力.但是无论如何,DDD都是一个起点.
下面是我总结的基于DDD发散的一些知识体系
下面会有简单的描述
仓储
DDD中仓储将持久化这个技术复杂性保持在领域模型之外.
具体来说有以下在具体实践中有以下几点:
- 隔离领域模型和数据模型:衍生出来就是隔离内存里面的模型和持久化模型.这个点会在EAV的设计中体现的淋漓尽致.
- 技术复杂度的封装:仓储负责如何组织模型存储.
静态分库:按照领域上下文(或者模块)分库,所谓纵向分库,在程序启动的时候就决定了某个实体该放到那个数据库,所以称之为静态.
动态分库:当某个库的数据量很大时候,这时候要对表数据做切割,所谓横向分库.在程序运行时候,针对某个实体的某条数据才能决定放到那个库,所以称之为动态.
- 规则横切. 将一些面向切面编程的逻辑放到仓储中.具体来说仓储主要控制的就是CRUD
软删除:那么只要在删除和查询的时候稍作处理即可实现软删除.
数据权限:只要在操作的时候判断,查询时候拼接条件即可实现数据的筛选.
应用程序服务
应用程序在我设计的时候我倾向于把契约和实现放到不同的项目中,基于这个偏好.慢慢演化出了如下思路
- Abp中有个方式直接把应用程序服务暴露出可以http访问的api
- 客户端用动态代理的方式+ioc即可实现访问契约,但是实际通过http请求调用
- 实现几个host方式,例如 IIS,Owin的Windows Service
- 基于Host动态加载程序集
从1-4是一个递进的过程,并非一簇而就或者一次性想到,而是不断重构优化产生的结果.
基于以上四步就已经接近一个应用程序容器.
PS: 这里其实还是刚刚起步 ,后续还有很多工作要做 ,目前还在实践演化中.
PS:应用程序容器是从单体架构到微服务的一个重要的重构手段.
领域上下文
在DDD中涉及到领域上下文这部分,是在宏观战略层面的部分,偏重于业务架构层面.
在微观中,涉及到的时候对某个类,或者某几个类的抽象和设计.
在宏观中,有时候需要把部分通用的功能进行抽离,即DDD中的支撑域.
另外上下文之间的通信也是这里要解决的问题.
- 微服务:这部分网上很多资料不细说
- 微应用:如果一个应用既有界面又有服务,我称之为微应用.
- 上下文通信:这部分涉及内部消息总线,外部消息队列,另外结合之前应用服务容器中的动态代理部分的通信方式.
- 战略设计: 其实就是部分支撑域的设计.虽然DDD中说更加看重核心域,但是在实际工作中发现,其实让团队成员集中精力
对业务进行设计,抽离一部分公有业务会减轻程序员很大一部分负担.
战略设计
ACS
这部分重点有就是ACS(权限控制系统).其中按照不同层级分为
- 应用级别权限:控制应用和应用之间的访问权限
- 用户级别权限:控制用户账户对系统的访问权限
- 功能级别权限:控制用户对某个功能的访问权限
- 数据级别权限:控制用户对某条数据的访问权限
基于功能级别的权限又演化出来一个逻辑应用的概念,实际应用是隔阂的,逻辑应用将多个系统功能合并成一个新的应用.
统计系统
基于每个系统都会产生统计的需要,这里引用CQRS的思想,将部分复杂的统计作为查询统一设计.
这个里面最核心的部分就是动态查询的设计.具体点就是将SQL和数据结构关联.作为SQL设计器的基础.
组件服务
- 计划任务:有部分定时任务会用windows service的方式host.并用调用应用的接口来实现定时触发.
- 通知中心:将站内,短信,邮箱,微信,移动端,推送做抽象.
- 附件:将附件的存储和获取与具体技术做隔离,并提供断点续传的功能.
聚合
其实这一部分发散开就是对业务逻辑的理解和设计.今年年初公司开始导入敏捷,感觉又打开一片新的天地.
DDD说领域驱动设计,很多时候只是提了一个原则,但是具体该如何来.慢慢接触到如下切入点:
- BDD(行为驱动设计)
- 实例化需求
- 用户故事
在宏观的业务需求梳理和分析的时候接触到《用户故事地图》.
基于敏捷接触到持续集成,慢慢接触到DevOps.
基于DevOps还设计了一个自动化测试工具.
敏捷和devops,是今年一年重点在学习的地方,也在不断的实践.
当然目前还是有很多问题急需解决.
总结
距离上一次发文已经很久了,有些知识经常不用就会忘记.
从这篇开始,会陆续有以上心得的分享,权当自我总结复习,欢迎大家讨论拍砖.
因为很多是源于公司的经验和业务,可能不会有全部的源码,但是重点部分会有的.
我一直觉得现并不重要,重要的是设计.
但是现在很多人都是更加注重某行代码怎么写.
现在互联网这么发达,这些具体技术点一般都很容易找到解决方案.
但是创新的设计思路却是找不到的,这些我觉得才是一个程序员的灵魂.
从DDD开始说起的更多相关文章
- 如何一步一步用DDD设计一个电商网站(九)—— 小心陷入值对象持久化的坑
阅读目录 前言 场景1的思考 场景2的思考 避坑方式 实践 结语 一.前言 在上一篇中(如何一步一步用DDD设计一个电商网站(八)—— 会员价的集成),有一行注释的代码: public interfa ...
- 如何一步一步用DDD设计一个电商网站(八)—— 会员价的集成
阅读目录 前言 建模 实现 结语 一.前言 前面几篇已经实现了一个基本的购买+售价计算的过程,这次再让售价丰满一些,增加一个会员价的概念.会员价在现在的主流电商中,是一个不大常见的模式,其带来的问题是 ...
- 如何一步一步用DDD设计一个电商网站(十)—— 一个完整的购物车
阅读目录 前言 回顾 梳理 实现 结语 一.前言 之前的文章中已经涉及到了购买商品加入购物车,购物车内购物项的金额计算等功能.本篇准备把剩下的购物车的基本概念一次处理完. 二.回顾 在动手之前我对之 ...
- 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念
一.前言 DDD(领域驱动设计)的一些介绍网上资料很多,这里就不继续描述了.自己使用领域驱动设计摸滚打爬也有2年多的时间,出于对知识的总结和分享,也是对自我理解的一个公开检验,介于博客园这个平 ...
- 如何一步一步用DDD设计一个电商网站(七)—— 实现售价上下文
阅读目录 前言 明确业务细节 建模 实现 结语 一.前言 上一篇我们已经确立的购买上下文和销售上下文的交互方式,传送门在此:http://www.cnblogs.com/Zachary-Fan/p/D ...
- 如何一步一步用DDD设计一个电商网站(六)—— 给购物车加点料,集成售价上下文
阅读目录 前言 如何在一个项目中实现多个上下文的业务 售价上下文与购买上下文的集成 结语 一.前言 前几篇已经实现了一个最简单的购买过程,这次开始往这个过程中增加一些东西.比如促销.会员价等,在我们的 ...
- 如何一步一步用DDD设计一个电商网站(五)—— 停下脚步,重新出发
阅读目录 前言 单元测试 纠正错误,重新出发 结语 一.前言 实际编码已经写了2篇了,在这过程中非常感谢有听到观点不同的声音,借着这个契机,今天这篇就把大家提出的建议一个个的过一遍,重新整理,重新出发 ...
- 如何一步一步用DDD设计一个电商网站(四)—— 把商品卖给用户
阅读目录 前言 怎么卖 领域服务的使用 回到现实 结语 一.前言 上篇中我们讲述了“把商品卖给用户”中的商品和用户的初步设计.现在把剩余的“卖”这个动作给做了.这里提醒一下,正常情况下,我们的每一步业 ...
- 如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域
一.前言 结合我们本次系列的第一篇博文中提到的上下文映射图(传送门:如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念),得知我们这个电商网站的核心域就是销售子域.因为电子商务是以信息网络 ...
- 如何一步一步用DDD设计一个电商网站(二)—— 项目架构
阅读目录 前言 六边形架构 终于开始建项目了 DDD中的3个臭皮匠 CQRS(Command Query Responsibility Segregation) 结语 一.前言 上一篇我们讲了DDD的 ...
随机推荐
- adb 安装apk 报错:Failure [INSTALL_FAILED_INVALID_URI]
今天在安装某apk的时候,发现报错 报错信息:Failure [INSTALL_FAILED_INVALID_URI] 于是找到了一个解决方式: cmd命令行下执行以下命令: 第一步.adb remo ...
- python中字符串中一些函数的用法
1..capitalize():字符串的首字母大写: 2..count():字符串中的某个字母的个数: 3..center(50,'-'):对象居中,且左右用'-'补齐: 4..encode():吧字 ...
- JavaScript封装一个MyAlert弹出框
平时我们想要显示一些提示信息时会用到alert方法,alert是全局的一个方法,会短暂的中断程序,我们主要用来显示提示客户信息.但是这个方法有一定的局限性,而且本身样式也不够美观.于是我封装了一个实用 ...
- 团队项目beta 汇总
一.冲刺计划安排 http://www.cnblogs.com/KKlist/p/6864124.html 二.七天的敏捷冲刺 第一天(2017.05.19) http://www.cnblogs.c ...
- 第二次项目冲刺(Beta阶段)第一天
a. 安排连续七天的敏捷冲刺. 2017.5.18完成冲刺计划安排 2017.5.20完善主页面 1st day(目前位置) 2017.5.21完善功能 2st day 2017.5.22添加自定义重 ...
- 201521123081《Java程序设计》 第8周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 参考资料:XMIND 1.2 选做:收集你认为有用的代码片段 2. 书面作业 本次作业题集 集合 Q1. Li ...
- 201521123101 《Java程序设计》第5周学习总结
1. 本周学习总结 2. 书面作业 1. 代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误.并分析输出结果. 不能 ...
- 201521123005《Java程序设计》第十三周学习总结
1. 本周学习总结 1.网络基本概念 2.网络常用命令 ipconfig 查看网络配置信息,如ip地址 ping 测试网络是否连通 telnet 远程登录 ftp 登陆ftp Fport (xp下)查 ...
- 201521123007《Java程序设计》第12周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2. 书面作业 将Student对象(属性:int id, String name,int age,doubl ...
- 201521123051《Java程序设计》第九周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. ·所有的异常类是从 java.lang.Exception 类继承的子类. ·Exception 类是 Throwa ...