为了落地DDD,我是这样“PUA”大家的
故事背景
准备阶段
下定决心
- 团队对老模式不满意,按照目前的状态,交付过程极其痛苦且风险高,大家渴望改善现状;
- 有成熟的DDD战术框架,团队要做的就是进行简单的熟悉即可,学习成本很低,一周内即可上手;
- 团队对我的信任达到了比较好的状态,这个决策大概率会被直属领导支持;
- 团队的大部分人心态都是开放的;
- 如果我们保持现在的步调,你觉得自己一年以后会成长成什么样子?
- 如果我说现在有一次团队革新的机会,如果成了,之前我给大家描绘的理想团队的样子就会成为现实,你是否愿意相信我。
- 如果我说有一套DDD战术框架,你只需要不到一周,就能驾驭它,你是否原因相信我。
- 如果保持现状的步调,未来也不会有太多成长,不会有新的东西,重复CRUD而已;
- 多学一些也无妨,不管是否如“你”所说,最终是否成功,对于自己都是有所收获的;
- 感觉可能没说得那么简单,但愿意试试;
最艰难的时刻
- 时间紧迫,有限的交付工期;
- 新老服务的衔接工作超出了预估;
- 与业务团队以及上级坦诚表达,工作量的实际情况,由于实际工作量比预期的要高,团队最终争取到了额外的一些研发时间;
- 集体关进会议室,做封闭式开发,我们发现用DDD的编码范式,一旦建模完毕,我们可以按照“命令-事件”将一个复杂流程分配给多个开发者,使得团队能够快速地协作开发,完成一个复杂功能;
- 团队组织了一定程度上的加班,这段时间,也是近一年来最辛苦的时刻;
变化与收益
- 业务建模,到编写代码不需要做太多的思考,代码可以与模型保持一致,不需要做翻译工作了;
- 对功能的迭代不再有负担感,感觉代码是可以驾驭的,这得益于DDD的代码组织方式,使得系统变更的影响范围,总是容易掌控的,代码变动的影响面非常容易掌控;
- 线上问题的修复相比以前更容易,新框架在数据的一致性方面有比较明显的健壮性,确保数据正确更容易;
- 更关注模型的设计是否符合预期;
- 从带着大家建模,进化为团队成员可以独立建模,并基本符合预期;
- 一旦模型确定,代码基本就确定了;
- 模型设计完毕后,工作量的估算比过去要准确得多,漏算的情况大幅减少;
意外的收获
- 他能够在一周左右的时间入门并使用DDD战术框架完成功能模块的开发
- 他能够在3个月的训练之后,按照DDD的思路参与建模工作
- 他设计的模型,会因为缺乏经验而对业务场景的分析不够充分
- 在已经落地DDD的环境下,学习DDD会非常容易;
- DDD的战术框架极其重要,为新人学习降低了理解门槛;
- 要做好建模,需要更多的业务和设计经验;
盗梦空间
终极奥义
- 真诚是最大的PUA
- 相信“相信的力量”
为了落地DDD,我是这样“PUA”大家的的更多相关文章
- 我们团队是如何落地DDD的(1)
最近发现文章老是被窃取,有些平台举报了还没有用.请识别我的id方丈的寺院. 摘要 DDD领域驱动设计,起源于2004年著名建模专家Eric Evans发表的他最具影响力的著名书籍:Domain-Dri ...
- 跨越DDD从理论到工程落地的鸿沟
摘要:本文从DDD的核心概念讲起,重点放在如何把理论落地成代码,期望给那些正在探索DDD的同学一些指引和启发. 本文分享自华为云社区<跨越DDD从理论到工程落地的鸿沟>,作者:敏捷小智. ...
- 可落地的DDD(7)-战术设计上的一些误区
背景 几年前我总结过DDD战术设计的一些落地经验可落地的DDD(5)-战术设计,和一次关于聚合根的激烈讨论最近两年有些新的落地体验,回过头来发现,当初对这些概念的理解还是没有深入,这篇文章重新阐述下. ...
- 在单体应用的一些DDD实践经验
阅读此文需要一定的DDD基础,如果你是第一次接触DDD读者,建议先去阅读一些DDD相关的书籍或者文章之后再来阅读本文. 背景 自从我在团队中推行DDD以来,我们团队经历了一系列的磨难--先是把核心项目 ...
- DDD-CQRS的落地案例
摘要 在之前的文章DDD-CQRS能解什么问题中,阐述了什么是CQRS.但是并没有业务需求可以应用CQRS.最近需要处理一个文本增量更新的业务,经过需求分析后,尝试使用CQRS来解这个问题 问题分析 ...
- 基于ABP落地领域驱动设计-02.聚合和聚合根的最佳实践和原则
目录 前言 聚合 聚合和聚合根原则 包含业务原则 单个单元原则 事务边界原则 可序列化原则 聚合和聚合根最佳实践 只通过ID引用其他聚合 用于 EF Core 和 关系型数据库 保持聚合根足够小 聚合 ...
- DDD领域驱动设计-概述-Ⅰ
如果我看得更远,那是因为我站在巨人的肩膀上.(If I have seen further it is by standing on ye shoulder of Giants.) ...
- 怎么说服领导,能让我用DDD架构肝项目?
作者:小傅哥 博客:https://bugstack.cn 原文:https://mp.weixin.qq.com/s/ezd-6xkRiNfPH1lGwhLd8Q 沉淀.分享.成长,让自己和他人都能 ...
- 领域驱动设计(DDD)在美团点评业务系统的实践
前言 至少 30 年以前,一些软件设计人员就已经意识到领域建模和设计的重要性,并形成一种思潮,Eric Evans 将其定义为领域驱动设计(Domain-Driven Design,简称 DDD).在 ...
- Vue的生命周期
1.1.实例生命周期 每个 Vue 实例在被创建之前都要经过一系列的初始化过程.例如需要设置数据监听.编译模板.挂载实例到 DOM.在数据变化时更新 DOM 等.同时在这个过程中也会运行一些叫做生命周 ...
随机推荐
- Unity中使用ProtocolBuffer
Unity中使用ProtocolBuffer unityProtocolBufferUnity ProtocolBuggerC# ProtocolBuffer Unity中使用ProtocolBuff ...
- Linux设备模型:4、sysfs
作者:wowo 发布于:2014-3-14 18:31 分类:统一设备模型 http://www.wowotech.net/device_model/dm_sysfs.html 前言 sysfs是一个 ...
- 如何查看docker容器的volume挂载情况
准备在docker容器当中编写个日常维护的脚本,但容器里连yum和vim命令都没有,所以就想到通过容器映射在本机的volume里编写脚本这样在容器中不就可以直接用了吗,那么在这之前你首先得知道dock ...
- AI Agent技术的最新进展与改变世界的典型项目巡礼
AI Agent技术的最新进展与改变世界的典型项目巡礼 1. AI Agent 技术发展以及典型项目 1.0 前 AI Agent 时代 在学术探索的浩瀚星空中,机器人技术领域的璀璨明珠莫过于Agen ...
- 解决方案 | AutoCAD 版本+版本号+受支持的 .NET SDK版本+.NET Framework版本
关于 Managed .NET 兼容性 Managed .NET 应用程序通常与扩展基于 AutoCAD 的产品的行为和功能的公司和第三方应用程序关联. 在移植到最新版本后,并非所有 .NET 应用程 ...
- 基于Java“萌宠之家”宠物综合服务平台设计实现(源码+lw+部署文档+讲解等)
\n文末获取源码联系 感兴趣的可以先收藏起来,大家在毕设选题,项目以及论文编写等相关问题都可以给我加好友咨询 系统介绍: 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面 ...
- Vue 根据鼠标悬停目标元素上方显示、隐藏指定元素交互实现
Vue 根据鼠标悬停目标元素上方显示.隐藏指定元素交互实现 By:授客 QQ:1033553122 开发环境 win10 element-ui "2.13.1" vue &qu ...
- vue codemirro 文件对比 sql编辑器
效果图: 安装及引用同上一篇文章,请移步:https://www.cnblogs.com/Lu-Lu/p/16265815.html HTML: <el-dialog class="d ...
- SEO初学指南之关键词研究(2) - 搜索意图分析
Hi,我是听风.这篇文章我们深入探讨下关键词研究中最重要的一点:搜索意图. 虽然这在本系列教程的第一篇中提到过搜索意图,但是我还是想再写一篇文章来帮助你们了解什么是搜索意图以及如何再关键词研究中使用它 ...
- springMvc使用自定义View生成Excel表格
1:通过自定义的View视图可以让请求直接到一个Excel表去. 2:自定义的视图必须继承 AbstractXlsView /AbstractXlsxView / AbstractXlsxStrea ...