为什么领导不愿意让你用DDD肝项目?
作者:小傅哥
博客:https://bugstack.cn
沉淀、分享、成长,让自己和他人都能有所收获!
一、前言
领导:为什么要使用DDD?
我也苦思冥想,怎么跟领导说咱们从 MVC 升级到 DDD 吧,因为 DDD 代码结构更加清晰、领域驱动比测试驱动开发更加先进、研发的兄弟们也更想用用新框架等。
不过这么聊被喷一顿不说,还得说你是过度设计瞎折腾,咋回事呢?因为没聊到重点呀,你MVC升级DDD;给业务带来了什么、提升了交付效率吗、降低了公司研发成本吗,都没有?不仅没有,你还说为了后期的迭代维护,前期会需要更多的设计和开发时间。咋?你是想这一个Q就把我送走吗,我刚来咱们部门KPI在那悬着,压的我头发都白了!别瞎搞,求稳!
那就不搞了吗?搞哇,不让搞换领导!但搞之前,要考虑清楚,DDD 不是 Silver Bullet,你有一腔热血虽好,可是也得知晓 DDD 的设计原则是什么、它更适合的场景是什么、与 MVC 对比有什么云泥之别。
二、开发成本
使用 DDD 模式开发代码的成本到底在哪?是因为使用 DDD 四层分层结构就比MVC 三层分层结构 更浪费时间吗?其实并不是,因为四层结构相对于三层结构,反而更好的区分了代码所属职责,在熟悉模块功能职责后,开发起来也会更加顺畅。
那这里的 DDD 领域驱动设计开发的成本在哪呢?这个成本在于对于一个复杂系统又尚未在开发前期就有非常充足的经验来拆分职责边界、划分功能领域、明确编排逻辑和对未知流程扩展的把控上,所带来的风暴模型设计成本。
而通常使用的 MVC 结构基本不会出现这样的问题,因为在实际的代码中,DAO、PO、VO等都是共用的,大家在开发代码的时候,像堆泥球一样面向过程写代码,直接串联出产品的PRD功能节点即可,不用过多的思考解耦和内聚。
那不是可以设计模式吗,这就需要看你是站在哪个维度去思考问题。设计模式在这里是战术问题的,DDD和MVC是确定战略问题的,有点像是说:“方向不对,努力白费一样”
那么现在我们再来看这条开发成本曲线:
架构模式,开发成本曲线
- 与其他两种分层结构相对比,使用 DDD 的时候,需要在前期投入较多的时间成本来设计领域建模,所以前期成本会更高一些。
- 但随着业务不断迭代后的逻辑的复杂性增加,DDD 系统架构所开发的代码稳定性会更好,也就说明 DDD 更容易扩容和维护。
- 所以框架结构的更换,不是最终增加开发成本的地方,如果你不做领域建模也不做更多的设计思考,那么即使是 DDD 的四层架构,也能让你写出 MVC 的效果。而那些对业务场景经验丰富的架构师或者研发人员,已经非常明确了各个业务功能的职责边界,要实现一个系统需求需要完成哪些核心领域服务,再这样的情况用 DDD 也不会带来多少开发成本,反而更加游刃有余了!这就是为什么说,需要领域专家,因为专家已经积累了很多的战略设计经验
- 此外使用 DDD 领域驱动设计的模式进行开发,除了解决需求的迭代成本,更多的时候是要面对公司战略调整后,系统的交接、人员的更替和新增,都要在原有的工程架构下继续迭代开发,否则就要推翻重新做,那样所面临的更替成本将更大,同时又是开发了一个与人员绑定不易于交接维护的工程代码。
三、架构对比
在了解和掌握 DDD 领域驱动设计的路上,你一定会碰到两个抽象的钉子 —— “贫血模型”、“充血模型”:
- 贫血模型:事务脚本模式,最早起源于 EJB2,到 Spring 进入开“春”盛世。
- 充血模型:领域模型模式,2003年提出,一直到《实现领域驱动设计》的问世,才开启了 DDD 的大门。但国内直到微服务、低代码的兴起,才开始 DDD 热
1. MVC
MVC 分层结构将:“状态”(数据,成员对象)、“行为“(逻辑、过程),分离到不同的对象中,只有状态的对象(VO -> Value Object) 被称为贫血模型,只有行为的对象,就是框架分层中常见的Logic/Service/Manager层(对应到EJB2中的Stateless Session Bean)
MVC 分层结构
- 以应用层 Service 使用 DAO、PO 基础设施包装业务逻辑的开发方式,乍一看以为应用层是在对领域建模的实现,”领域层“有着丰富的对象链接,和真正的领域模型也非常类似,但当我们代码随着业务功能逻辑的逐步实现中会慢慢发现,我们写了一堆的 get/set 对象,而他们被反复交叉使用,没有与任何领域聚合,也就是不具有任何的行为动作,只是一堆贫血模型对象。
- 这种反模式的设计,其实完全与面向对象的设计是背道而驰的,面向对象的设计更希望行为和数据绑定在一起,与之对比的贫血模型更像是面向过程设计。
- 在 MVC 分层结构下,所有的行为都被写入到 Service 对象中,最终你会得到一组事务处理的过程脚本,从而完美的避开了领域模型设计所带来的好处(清晰的职责边界、聚合的功能服务、清晰的面向对象)。
2. DDD
DDD 的分层结构也是面向对象编程的本质:”一个对象拥有行为和数据“,在领域层包括了:对象、聚合对象、仓储和Service实现。
DDD 分层结构
- DDD 的分层结构更注重 Domain 领域层的实现,由很薄的应用层定义接口和编排接口,由领域层做具体的实现。
- 所有的业务逻辑都按照各自的职责边界拆分成一块块的功能领域,每一个功能领域都是充血模型的结构的具体实现。
- 那么这样的代码最终实现以后,无论在迭代、维护、人员更替,都能很好按照领域设计文档找到对应的代码实现进行开发。
四、设计原则
首先 DDD 的设计分为战略和战术;
- 战略设计:从业务视角出发,建立业务领域模型、划分职责边界,建立通用语言的界限上下文。顶层战略设计构建的领域模型结构,是整个服务后期编排的重点,它确定了功能的职责边界、聚合、对象等,也就决定了后期服务战术实现的开发和交付质量。重视战略,才能落地好战术!
- 战术设计:从技术视角出发,侧重于领域模型的技术实现,完成功能开发和交付落地。领域设计的重点包括:实体、聚合对象、值对象、领域服务、仓储,还有一个非常重点的设计模式。任何一个较为复杂的领域模型实现都需要考虑设计模式的使用,否则即使战略优秀,战术也能干回 MVC 去。
在以DDD领域驱动设计落地的过程中,要依靠领域驱动设计的设计思想,通过事件风暴建立领域模型,合理划分领域逻辑和物理边界,建立领域对象及服务矩阵和服务架构图,定义符合DDD分层架构思想的代码结构模型,保证业务模型与代码模型的一致性。通过上述设计思想、方法和过程,指导团队按照DDD设计思想完成微服务设计和开发。
- 拒绝泥球小单体、拒绝污染功能与服务、拒绝加功能排期一个月
- 架构出高可用极易符合互联网高速迭代的应用服务
- 物料化、组装化、可编排的服务,提高人效
- 要领域驱动设计,而不是数据驱动设计,也不是界面驱动设计
- 要职能清晰的分层,而不是什么都放的大箩筐
DDD 的领域模型设计,界限内的上下文,可以拆分为独立的微服务。但不仅要从业务视角看问题,也要考虑非业务的技术因素,包括:高性能、安全、团队、技术异构等,这些非业务的技术因素,也会决定领域模型落地的具体落地。
五、举个例子
你说我 MVC 不好,你说我 MVC 贫血模型,PO 类不断的膨胀,但让我用 DDD 又都是理论,程序员更喜欢看的是已经落地的代码,告诉我怎么干。
为什么这么难落地呢?因为从 MVC 过度到 DDD 描述对比只是积累了 MVC 失败的教训,但没有 DDD 成功的经验,所以更多的时候想落地 DDD 除了有理论支撑,更需要一份案例摆在面前。
1. 案例工程
所以为了让更多的码农看到在 DDD 上一条能走的路,专门折腾了个 DDD 分布式抽奖系统,来告诉大家怎么使用 DDD 开发业务需求;
DDD 分布式抽奖系统,工程分布
整体系统架构设计包含了6个工程:
- Lottery:分布式部署的抽奖服务系统,提供抽奖业务领域功能,以分布式部署的方式提供 RPC 服务。
- Lottery-API:网关API服务,提供;H5 页面抽奖、公众号开发回复消息抽奖。
- Lottery-Front:C端用户系统,vue H5 lucky-canvas 大转盘抽奖界面,讲解 vue 工程创建、引入模块、开发接口、跨域访问和功能实现
- Lottery-ERP:B端运营系统,满足运营人员对于活动的查询、配置、修改、审核等操作。
- DB-Router:分库分表路由组件,开发一个基于 HashMap 核心设计原理,使用哈希散列+扰动函数的方式,把数据散列到多个库表中的组件,并验证使用。
- Lottery-Test:测试验证系统,用于测试验证RPC服务、系统功能调用的测试系统。
2. 流程拆解
当我们拿到产品的 RPD 以后,并不是直接上手开发,而是需要从流程中拆解出一份面向对象设计的领域服务,举例;
DDD 分布式抽奖系统,流程拆解
- 拆解功能流程,提炼领域服务,一步步教会你把一个业务功能流程如何拆解为各个职责边界下的领域模块,在通过把开发好的领域服务在应用层进行串联,提供整个服务链路。
- 通过这样的设计和落地思想,以及在把流程化的功能按照面向对象的思路使用设计模式进行设计,让每一步代码都变得清晰易懂,这样实现出来的代码也就更加易于维护和扩展了。
- 所以,你在这个过程中学会的不只是代码开发,还有更多的落地思想实践在这里面体现出来。也能为你以后开发这样的一个项目或者在面试过程中,一些实际复杂场景问题的设计思路,打下不错的基础。
六、总结
- DDD 并不是 Silver Bullet,你并不能指望换个了个框架结构,就能改变堆屎山?似的开发代码,所带来坏味道问题。MVC 结构一样可以开发出好的代码,只是它的稳定性更差,不利于长期维护和迭代。
- DDD 的复杂性是因为缺少领域建模的经验,如果同一个需求你已经在 MVC 的中嚯嚯的吸收了足够的边界上下文总结,现在换 DDD 可以让你更快的开发代码。
- DDD 也并不是所有工程模型结构都复杂,DDD 是指导思想,你可以在 DDD 四层架构中因为引入 RPC 拆解各个模块的分层,也可以因业务规模在中等及复杂度时不引入 RPC 框架,这样的 DDD 会更加短小精干,与 MVC 相比只是在领域层定义接口,把代码放到 domain 层做实现,数据放到仓储层处理。
探秘Clash官网:如何精准获取代理配置URL全攻略
引言:当网络自由遇见技术工具
在信息洪流的时代,网络边界逐渐模糊,而工具的选择往往决定了我们探索世界的深度。Clash作为一款集规则代理、多协议支持和流量管理于一身的开源工具,已成为技术爱好者与隐私重视者的"数字瑞士军刀"。然而,许多用户在初次接触时,常陷入"官网信息繁杂,关键URL难寻"的困境。本文将化身您的数字向导,从核心概念到实操细节,层层拆解Clash官网的信息架构,带您掌握高效获取配置资源的艺术。
第一章:认识Clash——不只是代理工具
1.1 工具本质与时代意义
Clash并非简单的流量转发器,而是一个支持Vmess、Shadowsocks、Trojan等多协议的规则引擎。其独创的"策略组"功能允许用户根据域名、IP、地理位置等维度智能分流流量,这种设计理念使其在2019年迅速超越传统代理工具,成为GitHub上星标增长最快的网络工具之一。
1.2 技术架构的革新性
相较于早期代理工具的单一链路设计,Clash采用YAML配置体系,将规则、代理、DNS等模块解耦。这种架构使得用户可以通过修改配置文件实现:
- 广告拦截与隐私追踪屏蔽
- 跨国流媒体智能解锁
- 企业内网与公网流量分离
最新发布的Clash Meta分支甚至支持WireGuard协议,进一步拓展了技术边界。
第二章:官网导航——信息矩阵的解密手册
2.1 官方入口的甄别艺术
真正的官网永远驻留在GitHub:
https://github.com/Dreamacro/clash
警惕仿冒站点!官方页面具有三个显著特征:
- Dreamacro作者账号的"Verified"认证标志
- 超过50k的Star数量(截至2023年)
- 每周更新的Release版本记录
2.2 页面结构的黄金三角
官网信息呈现三维立体结构:
| 区域 | 核心内容 | 隐藏技巧 |
|-------------|-----------------------------------|------------------------------|
| README | 基础介绍与快速启动 | 查看"Advanced"折叠栏位 |
| Releases | 历史版本与二进制下载 | 使用Ctrl+F搜索"pre-release" |
| Wiki | 完整文档与配置示例 | 关注"Rule Providers"专题页面 |
第三章:URL猎取实战——从新手到专家
3.1 基础配置的寻宝路线
步骤一:定位配置文件模板
在Wiki的"Configuration"章节中,官方提供了config.yaml
标准模板。关键URL往往隐藏在:
yaml proxy-providers: provider1: url: "https://example.com/profile" interval: 3600
步骤二:捕获规则集链接
向下滚动至"Rule Providers"部分,可见类似结构:
yaml rule-providers: reject: url: "https://ruleset.example.com/adblock"
3.2 高阶用户的深度挖掘
Git历史考古法
点击Wiki页面的"History"按钮,查看2020年的历史版本,常保留着未被删除的测试用URLIssue追踪术
在已关闭的Issue中搜索"config example",开发者常在此分享临时配置依赖库逆向解析
检查go.mod文件中的依赖项,相关项目可能提供备用镜像
第四章:安全操作指南——避开暗礁的航海图
4.1 真实性验证四重奏
- HTTPS证书检查:所有官方URL必须启用TLS1.3
- 哈希值比对:使用
shasum -a 256 downloaded_file
核对发布页面的校验值 - 域名年龄验证:通过Whois查询确认域名注册时间超过1年
- 社区共识确认:在Reddit的r/Clash子版块搜索该URL的讨论记录
4.2 动态维护策略
- 建立本地资源库:使用Git克隆Wiki仓库定期同步
bash git clone https://github.com/Dreamacro/clash.wiki.git
- 配置自动化监控:通过GitHub API设置版本更新提醒
```python
示例:监测Release更新的Python脚本
import requests
r = requests.get('https://api.github.com/repos/Dreamacro/clash/releases/latest')
print(r.json()['published_at'])
```
第五章:疑难排解——迷雾中的信号灯
5.1 典型问题解决方案
场景一:URL导入失败
- 现象:客户端提示"invalid configuration"
- 诊断流程:
1. 使用在线YAML验证器检查语法
2. 临时关闭Clash的"enhanced-mode"
3. 在VSCode中安装Clash插件进行可视化调试
场景二:订阅链接过期
- 应急方案:
1. 访问https://github.com/Dreamacro/clash/issues/
按时间排序
2. 搜索关键词"alternative endpoint"
3. 使用公共API缓存服务如web.archive.org
回溯历史页面
结语:技术素养的进化之旅
掌握Clash官网的信息检索,本质上是一场元学习能力的锻炼。在这个过程中,我们不仅收获了工具使用的具体知识,更培养了在开源生态中高效获取信息的思维模式。当您能像阅读城市地图般自如地浏览GitHub仓库时,便已悄然跻身数字时代的"技术公民"行列。记住:每一个URL背后都连接着无限可能,而您的探索,正在重新定义网络的边界。
语言艺术点评:
本文采用技术散文的写作风格,将枯燥的操作指南升华为知识探索的叙事。通过军事术语("数字瑞士军刀")、航海隐喻("避开暗礁")等修辞手法,赋予技术文档文学感染力。段落结构借鉴学术论文的严谨性,同时穿插代码块、表格等多媒体元素,形成"立体化"的信息呈现。特别在第四章引入诗歌式的四重奏结构,使安全规范产生韵律美感,这种将理性认知与感性表达融合的写法,正是当代科技写作的典范。
版权声明:
作者: freeclashnode
链接: https://www.freeclashnode.com/news/article-2634.htm
来源: FreeClashNode
文章版权归作者所有,未经允许请勿转载。
热门文章
- 6月27日|18.9M/S,Shadowrocket(小火箭)/V2ray/Clash(小猫咪)免费节点订阅链接每天更新
- 6月23日|21.1M/S,Clash(小猫咪)/Shadowrocket(小火箭)/V2ray免费节点订阅链接每天更新
- 6月28日|22.2M/S,V2ray/Clash(小猫咪)/Shadowrocket(小火箭)免费节点订阅链接每天更新
- 6月26日|23M/S,Clash(小猫咪)/V2ray/SSR免费节点订阅链接每天更新
- 6月22日|18.4M/S,V2ray/Shadowrocket(小火箭)/Clash(小猫咪)免费节点订阅链接每天更新
- 6月24日|19.8M/S,Shadowrocket(小火箭)/V2ray/Clash(小猫咪)免费节点订阅链接每天更新
- 7月1日|21.7M/S,Clash(小猫咪)/V2ray/Shadowrocket(小火箭)免费节点订阅链接每天更新
- 6月29日|20.9M/S,Shadowrocket(小火箭)/V2ray/Clash(小猫咪)免费节点订阅链接每天更新
- 7月2日|20.9M/S,Clash(小猫咪)/SSR/V2ray免费节点订阅链接每天更新
- 6月30日|22.7M/S,Clash(小猫咪)/Shadowrocket(小火箭)/V2ray免费节点订阅链接每天更新
最新文章
- 7月18日|19.1M/S,Shadowrocket(小火箭)/V2ray/Clash(小猫咪)免费节点订阅链接每天更新
- 7月17日|22M/S,Shadowrocket(小火箭)/Clash(小猫咪)/V2ray免费节点订阅链接每天更新
- 7月16日|20.3M/S,SSR/Clash(小猫咪)/V2ray免费节点订阅链接每天更新
- 7月15日|22.9M/S,Clash(小猫咪)/SSR/V2ray免费节点订阅链接每天更新
- 7月14日|22.8M/S,Clash(小猫咪)/V2ray/SSR免费节点订阅链接每天更新
- 7月13日|19.9M/S,Clash(小猫咪)/Shadowrocket(小火箭)/V2ray免费节点订阅链接每天更新
- 7月12日|22.3M/S,Clash(小猫咪)/V2ray/Shadowrocket(小火箭)免费节点订阅链接每天更新
- 7月11日|21.4M/S,Clash(小猫咪)/V2ray/Shadowrocket(小火箭)免费节点订阅链接每天更新
- 7月10日|21.6M/S,V2ray/Shadowrocket(小火箭)/Clash(小猫咪)免费节点订阅链接每天更新
- 7月9日|19.6M/S,SSR/V2ray/Clash(小猫咪)免费节点订阅链接每天更新