Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/feiniaojin/ddd-archetype
Maven Atchetype,implements the layered application architecture of Domain Driven Design(DDD)
https://github.com/feiniaojin/ddd-archetype
ddd domain-driven-design maven-archetype spring-boot
Last synced: 5 days ago
JSON representation
Maven Atchetype,implements the layered application architecture of Domain Driven Design(DDD)
- Host: GitHub
- URL: https://github.com/feiniaojin/ddd-archetype
- Owner: feiniaojin
- License: mit
- Created: 2022-07-12T06:28:29.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-05T02:06:45.000Z (about 2 months ago)
- Last Synced: 2025-01-13T13:21:21.668Z (13 days ago)
- Topics: ddd, domain-driven-design, maven-archetype, spring-boot
- Language: Java
- Homepage: https://doc.feiniaojin.com
- Size: 251 KB
- Stars: 61
- Watchers: 3
- Forks: 23
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 1. ddd-archetype介绍
本项目是作者《悟道领域驱动设计》书中采用的应用架构的脚手架。《悟道领域驱动设计》一书是作者多年实战领域驱动设计的总结,力求用最平实、最通俗、最容易理解的方式将DDD分享给各位朋友,目前该书已上架各大电商平台,感兴趣的朋友可以帮忙支持一下。
购买链接:https://item.jd.com/14835288.html
关于该应用架构,详细见[第2章 应用架构](https://ddd.feiniaojin.com/2.html)。我们在落地DDD应用架构时,通常将项目分为多个Maven Module,如下图。
[![架构图](https://gingoimg.oss-cn-beijing.aliyuncs.com/ddd/ddd-%E6%9E%B6%E6%9E%84.png)](https://gingoimg.oss-cn-beijing.aliyuncs.com/ddd/ddd-%E6%9E%B6%E6%9E%84.png)
如果每个项目都手工创建一次,是比较繁琐的工作,也不利项目结构的统一。Maven
Archetype是一个Maven插件,它允许开发人员通过指定一组参数来创建项目的基础结构,可以帮助开发人员快速创建项目的基础结构,大大减少开发人员在创建项目时所需的时间和精力,并且可以确保项目结构的一致性和可重用性,从而提高代码质量和可维护性。ddd-archetype是一个Maven Archetype的原型工程,我们将其克隆到本地之后,可以安装为Maven Archetype,帮助我们快速创建DDD项目脚手架。
欢迎star!
# 2. ddd-archetype的安装使用
## 2.1 安装过程
以下将以IDEA为例展示ddd-archetype的安装使用过程,主要过程是:
`克隆项目`-->`archetype:create-from-project`-->`install`-->`archetype:crawl`
### 2.1.1 克隆项目
将项目克隆到本地:
```shell
git clone https://github.com/feiniaojin/ddd-archetype.git
```直接使用主分支即可,然后使用IDEA打开该项目
[![p9olKXQ.png](https://s1.ax1x.com/2023/05/22/p9olKXQ.png)](https://imgse.com/i/p9olKXQ)
### 2.1.2 archetype:create-from-project
配置打开IDEA的`run/debug configurations`窗口,如下:
[![p9ol17n.png](https://s1.ax1x.com/2023/05/22/p9ol17n.png)](https://imgse.com/i/p9ol17n)选择`add new configurations`,弹出以下窗口:
[![p9olGt0.png](https://s1.ax1x.com/2023/05/22/p9olGt0.png)](https://imgse.com/i/p9olGt0)其中,上图中1~4各个标识的值为:
标识`1` - 选择"+"号;
标识`2` - 选择"Maven";
标识`3` - 命令为:
```shell
archetype:create-from-project -Darchetype.properties=archetype.properties
```> 注意,在IDEA中添加的命令默认不需要加mvn
标识`4` - 选择`ddd-archetype`的根目录
以上配置完成后,点击执行该命令。
### 2.1.3 install
上一步执行完成且无报错之后,配置`install`命令。
[![p9oltpT.png](https://s1.ax1x.com/2023/05/22/p9oltpT.png)](https://imgse.com/i/p9oltpT)
其中,上图中1~2各个标识的值为:
标识`1` - 值为`install`;
标识`2` - 值为上一步运行的结果,路径为:
```
ddd-archetype/target/generated-sources/archetype
````install`配置完成之后,点击执行。
### 2.1.4 archetype:crawl
`install`执行完成且无报错,接着配置`archetype:crawl`命令。
[![p9olN1U.png](https://s1.ax1x.com/2023/05/22/p9olN1U.png)](https://imgse.com/i/p9olN1U)
其中,标识1中的值为:
```shell
archetype:crawl
```配置完成,点击执行即可。
## 2.2 使用ddd-archetype初始化项目
- 创建项目时,点击`manage catalogs`:
[![p9olaX4.png](https://s1.ax1x.com/2023/05/22/p9olaX4.png)](https://imgse.com/i/p9olaX4)- 将本地的maven私服中的`archetype-catalog.xml`加入到catalogs中:
[![p9ol0B9.png](https://s1.ax1x.com/2023/05/22/p9ol0B9.png)](https://imgse.com/i/p9ol0B9)添加成功,如下:
[![p9olrA1.png](https://s1.ax1x.com/2023/05/22/p9olrA1.png)](https://imgse.com/i/p9olrA1)- 创建项目时,选择本地archetype-catalog,并且选择`ddd-archetype`,填入项目信息并创建项目:
[![p9olstx.png](https://s1.ax1x.com/2023/05/22/p9olstx.png)](https://imgse.com/i/p9olstx)- 项目创建完成后:
[![p9TtUh9.png](https://s1.ax1x.com/2023/05/23/p9TtUh9.png)](https://imgse.com/i/p9TtUh9)
# 3. 成功案例作者已使用该脚手架完成许多项目的开发,其中开源出来的案例见[随书示例代码](https://ddd.feiniaojin.com/samples.html)。
# 4. DDD学习交流群
欢迎加入DDD交流群。微信扫以下二维码添加作者微信,标注“DDD”,好友申请通过后拉您进群。