
一个基于 NestJS 10 + TypeORM 的领域驱动设计( DDD ) Node.js 脚手架,内置双数据库、领域事件、统一响应、Swagger 文档与 Docker 一键启动示例。
nestjs-ddd 是一个面向 Node.js / TypeScript 的 DDD 工程脚手架,帮你用几分钟时间搭好一个符合 DDD 分层规范的后端服务。
项目内置 用户( User ) 和 订单( Order ) 两个示例聚合,用户库走 MySQL 、订单库走 PostgreSQL ,包含 15 个 REST 接口、领域事件发布与监听、Swagger 文档、Docker Compose 一键启动。
功能与 gin-ddd / springboot4ddd 对齐,便于对比不同语言栈在 DDD 工程中的落地差异。
practice-projects/nestjs-ddd/NestJS-DDD-Development-Guide.md| 层 | 关注点 | 约束 |
|---|---|---|
| 接口层 | HTTP 协议适配( VO / 路由 / 过滤器) | 不写业务逻辑 |
| 应用层 | 用例编排、事务、DTO / Command | 只依赖领域层 |
| 领域层 | 业务规则、聚合、领域事件、仓储接口 | 零框架依赖 |
| 基础设施层 | TypeORM 、消息、邮件等技术实现 | 向上实现领域接口 |
一句话:MVC 按技术切,DDD 按业务切。业务越复杂,DDD 的价值越明显。
有人会觉得:Node.js 是不是写写脚本、BFF 就够了,没必要用 DDD ?
结论很简单:用不用 DDD 和语言无关,和业务复杂度有关。
Module / Controller / Service 三件套就够用,没必要上 DDD 。