【ArchSummit】如何通过AIOps推动可量化的业务价值增长和效率提升?>>> 了解详情
写点什么

DDD 项目失败的几个原因

  • 2020-05-09
  • 本文字数:1955 字

    阅读完需:约 6 分钟

DDD 项目失败的几个原因

为什么想写这个,主要是感受到同志们的学习高潮,恨不得各种练习,但又遭遇到一些挑战,比如“我想在项目中推行 DDD,但担心其他人不配合”,“DDD 门槛太高,概念多”…



就笔者之所见,一个标榜实践 TDD 的项目要不是口号,噱头,要不就失败了,如同要推行 DDD 的一样。项目不是兵器的练兵场,首先要回到“问题域”,要解决什么问题。


一个以推行 DDD 为目标的项目,总觉得有点慌。


就笔者之所见所闻,有 1 个典型的推广 XXX 的 case。


一个是某司的一位空降 boss,是一位有创派别的国内“敏捷”专家。当然,敏捷专家几乎都耻于谈敏捷 ,这样也就和其他人谈的“敏捷”无法区分开去。空降 boss 一来就感觉到这个团队在代码匠艺 、发布、甚至设计抽象都存在某些不足,于是大谈敏捷实践和各种老外前辈云云,但却被团队吐槽,因为那会这群码农最关心的是“生存问题”,去总部找活回来干的问题 。几个月后这位 boss 转变了思路,通过抓稳定迭代的 release,促进快速反馈“挽尊”,此是后话。


这个 case,让人懂得了 一个道理,一位病人发烧了,医生可以先采取措施让他退烧,然后治疗。病人并不喜欢医生跟他讲中西医区别,药理知识。第二个道理就是,鸡蛋好吃,你非要去分辨是那只鸡下的蛋,并无多大必要。


团队员工的期待是空降老板给我们指方向,找活干,加薪而不是推广敏捷 。


同理,江湖上流传着这样的说法:


老板看问题的视角是,“这个需求很简单,怎么实现我不管”。


某些技术人员的视角可能是,“十八般武艺都用,至少面试用得着”。


另外很诡异的一个点在于,人类对于所谓 “建议”往往听不进去,然后总会找到一堆来证伪,然后又乐此不彼的“学习着”,争论他认为对的观点…


笔者自己也做过推广 XXX 的事情,持续集成。这东西大家都知道,我们之前有一个简单的规约,就是每天下班前的构建要绿色 ,单元测试和接口测试都得通过。好些同学怨声一片,代码都写不完,干嘛还要去写测试代码?尤其是之前测试代码覆盖率巨低的系统,几百个测试 case 不通过的系统 …


采取简单粗暴的每天强制的方式,存量用例设定计划治理,研发同学不情愿的被要求每天跑 CI…在大显示屏的曝光和强迫之下,持续了半年多… 后来有项目团队主动分享 CI 带来的好处,测试代码在他们后面的重构过程中发挥了作用,心里有底多了。


这个故事让我“自以为是”的懂得了第二个道理,让人懂得或者转变是很难的,猴子自己上树和抽猴子屁股上树的区别。如果你拿着香蕉在猴子面前晃,就不一样了。


Greg Young 先生有一个 presentation ,主题就是“


7 Reasons Why DDD Projects Fail“,简单总结 DDD 失败的要点:


Lack of intent(缺乏意图)


Anemic Domain Model(贫血模型)


DDD-Lite


Lack of isolation (缺乏隔离)


Ubiquitous what?


Lack of refinement(缺乏完善)


Proxy Domain Expert (Business analyst)


笔者稍微谈一下自己的理解。


1、首要解决通用语言 UL(Ubiquitous Language 问题,统一域语言。


张逸老师指出,统一语言是提炼领域知识的产出物,获得统一语言就是需求分析的过程,也是团队中各个角色就系统目标、范围与具体功能达成一致的过程。使用统一语言可以帮助我们将参与讨论的客户、领域专家与开发团队拉到同一个维度空间进行讨论,若没有达成这种一致性,那就是鸡同鸭讲,毫无沟通效率,相反还可能造成误解。因此,在沟通需求时,团队中的每个人都应使用统一语言进行交流。


可以想象一下,做支付、银行、电商行业的朋友在谈及记账、清算、结算、核算这些词的时候是否是一个明确统一的含义。一旦确定了统一语言,无论是与领域专家的讨论,还是最终的实现代码,都可以通过使用相同的术语,清晰准确地定义领域知识。重要的是,当我们建立了符合整个团队皆认同的一套统一语言后,就可以在此基础上寻找正确的领域概念,为建立领域模型提供重要参考。


2、没有基于通用语言建立的所谓的聚合,实体,值对象,只能算是 DDDLite,只是技术层面的一种设计方式。


3、要解决好隔离问题,则需要以一种最宏观的角度去对“问题域”进行拆分,来划分“界限上下文”,最终形成一个具有俯瞰视角的“上下文映射图”。这里特别说一下“界限上下文”和问题域、以及服务谁,产生什么价值息息相关。比如一个采用第三方支付(支付宝)的网站,并不对支付宝背后的网联,以及银行渠道进行建模。


4、refinement 的问题


架构腐化见怪不怪,如何领域层腐化了就“烂到跟上”。笔者见过一个系统,初期磨拳搽掌,建造者经验丰富,算是很成功的开端。但是若干年后这个系统 domain 层的代码和当初的领域模型图大相径庭,面目全非。持续的 refinement、保鲜非常重要。


另外,前几天和一位 TL 聊天,他说,我很注重代码追求的,为什么 1 年多我没怎么看代码,他们完全不是按照我想象的样子在写代码。


本文转载自技术锁话公众号。


原文链接:https://mp.weixin.qq.com/s/39Xqd9bVtTAGzXn1B_vxkg


2020-05-09 16:001039

评论

发布
暂无评论
发现更多内容

HarmonyOS走进西安电子科技大学国际双创周

科技汇

iOS底层面试题(上篇)

程序员 面试

大专的我,闭关56天,含泪拿下阿里offer,五轮面试,六个小时灵魂拷问

DEMO CHINA带着1000+投资人,500+好项目首登重庆

创业邦

创业 投资

关于程序猿的28个经典段子

程序员崩溃的40个瞬间!最后一个是你意想不到的.....

DataPipeline正式成为信创工委会会员单位!致力于为世界级用户提供更优质产品和服务

DataPipeline数见科技

大数据 数据融合 数据管理

直接裂开!京东二面被问SpringBoot整合MongoDB,我不会啊

Java架构没有996

Java mongodb 程序员 后端 JAVA开发

毕业总结

菲尼克斯

架构实战营

Linux安装与常用命令

IT视界

Linux linux命令 Linux安装

从零开始学习3D可视化之演示项目

ThingJS数字孪生引擎

大前端 可视化 3D 3D可视化

阿里大佬的「算法界Offer收割机」火爆Github,一夜获上万star

Java 编程 程序员 架构师 计算机

Linux文件查找常用命令-详细笔记

学神来啦

云计算 Linux 运维

融云技术分享:全面揭秘亿级IM消息的可靠投递机制

JackJiang

即时通讯 IM 可靠消息最终一致 融云

「腾讯面试题」兔子试毒

别人都在谈爱琴海,凭什么程序员就“地中海”网友:还是太优秀!

语言特性实战(一)

南冥

Rancher × Apache APISIX:极速部署更好用的开源网关和 Ingress Controller

API7.ai 技术团队

Kubernetes 网关 rancher APISIX

技术解码丨实时音视频与PSTN融合的解决方案

腾讯云音视频

腾讯云 音视频 PSTN

程序员工资高,到底程序员的工资有多高?你不了解的程序员!

程序员面试时自称字节跳动工作两年,被发现学历造假,结果蒙了!

应聘高级Android工程师历程感言,你不懂还不学?

欢喜学安卓

android 程序员 面试 移动开发

程序员是如何看待程序员的,程序员是做什么的?

海归硕士程序员吐槽:回国一个月都没找到工作,我书都白读了?

SpringBoot中时间格式化的5种方法!

王磊

spring springboot

一萌妹子的面试经历,美团四面三小时,成功拿到Java岗offer

白亦杨

Java 编程 程序员 架构师 计算机

云原生时代,服务网格能给企业带来哪些价值?

行云创新

云原生 解决方案 服务网格

最壕58人逆天改命:四面阿里拿offer后,才发现师哥给的面试笔记有多强大

Java架构师迁哥

程序员小哥月入5万,却被丈母娘拒绝,丈母娘一番话让小哥很尴尬

花费近一年时间整理的Android核心知识清单,面试篇

欢喜学安卓

android 程序员 面试 移动开发

程序员没两把刷子,就别送外卖了!!!

DDD 项目失败的几个原因_行业深度_技术琐话_InfoQ精选文章