博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Maven 模块化开发
阅读量:4457 次
发布时间:2019-06-08

本文共 11530 字,大约阅读时间需要 38 分钟。

(1)Maven 模块化开发

在多人协同开发时,特别是规模较大的项目,为了方便日后的代码维护和管理,我们会将每个开发人员的工作细分到具体的功能和模块上。随着项目的不断扩大,模块也会越来越多,后续会更加难以维护和扩展,为了应对这种情况可以采用微服务架构的方式进行开发。

以商城为例,我们可以将模块划分为如下形式:

  • 统一的依赖管理(dependencies)
  • 通用的工具类(commons)
  • 领域模型(domain)
  • 管理后台(admin)
  • 商城前端(ui)
  • 接口模块(api)

整个模块化开发过程主要是在开发思想上稍作了一些转变,只需要按照下面的流程操作即可。

创建根项目(工程)

把之前的my-shop项目修改成my-shop-bak,然后重新创建一个名 my-shop 的工程(在e盘某个目录下创建一个叫my-shop的文件夹,在IDEA打开该文件夹),现在my-shop不叫项目了,叫工程,工程是模块化开发的。

新建工程的pom.xml 文件

代码如下:

4.0.0
com.xue
my-shop
1.0.0-SNAPSHOT
pom

 

该项目称之为 Root 项目,主要作用是管理整个工程的全部模块,当有新模块加入时需要在 modules 元素下配置对应的模块目录

创建统一的依赖管理

在my-shop工程下创建一个名为 my-shop-dependencies 的项目,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop
1.0.0-SNAPSHOT
../pom.xml
my-shop-dependencies
pom
my-shop-dependencies
UTF-8
UTF-8
1.8
3.5
1.2
1.2.17
3.1.0
1.7.25
4.3.17.RELEASE
org.springframework
spring-context
${spring.version}
org.springframework
spring-webmvc
${spring.version}
javax.servlet
javax.servlet-api
${servlet-api.version}
provided
javax.servlet
jstl
${jstl.version}
org.slf4j
slf4j-api
${slf4j.version}
org.slf4j
slf4j-log4j12
${slf4j.version}
org.slf4j
jcl-over-slf4j
${slf4j.version}
org.slf4j
jul-to-slf4j
${slf4j.version}
log4j
log4j
${log4j.version}
org.apache.commons
commons-lang3
${commons-lang3.version}
org.apache.maven.plugins
maven-compiler-plugin
3.7.0
${java.version}
${java.version}
${project.build.sourceEncoding}
true
src/main/java
**/*.java
src/main/resources

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-dependencies</module> 配置

my-shop-dependencies

 

创建通用的工具类

在my-shop工程下创建一个名为 my-shop-commons 的项目,用于存放所有的工具类的,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop-dependencies
1.0.0-SNAPSHOT
../my-shop-dependencies/pom.xml
my-shop-commons
jar
my-shop-commons
org.apache.commons
commons-lang3
org.slf4j
slf4j-api
org.slf4j
slf4j-log4j12
org.slf4j
jcl-over-slf4j
org.slf4j
jul-to-slf4j
log4j
log4j

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-commons</module> 配置

my-shop-dependencies
my-shop-commons

 

创建领域模型

在my-shop工程下创建一个名为 my-shop-domain 的项目,用于存放所有的实体类的,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop-dependencies
1.0.0-SNAPSHOT
../my-shop-dependencies/pom.xml
my-shop-domain
jar
my-shop-domain

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-web-admin</module> 配置

my-shop-dependencies
my-shop-commons
my-shop-domain

 

创建管理后台

在my-shop工程下创建一个名为 my-shop-web-admin 的项目,用于存放所有的后台的相关代码的,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop-dependencies
1.0.0-SNAPSHOT
../my-shop-dependencies/pom.xml
my-shop-web-admin
war
my-shop-web-admin
com.xue
my-shop-domain
${project.parent.version}
com.xue
my-shop-commons
${project.parent.version}
org.springframework
spring-context
org.springframework
spring-webmvc
javax.servlet
javax.servlet-api
provided
javax.servlet
jstl

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-web-admin</module> 配置

my-shop-dependencies
my-shop-commons
my-shop-domain
my-shop-web-admin

 

注意

由于我们用的快照版,当工程或者某个项目的某个版本号更改了,这时候我们需要总是更新快照版,修改setting的maven image

创建商城前端

在my-shop工程下创建一个名为 my-shop-web-ui 的项目,用于存放所有的商城前台的相关代码的,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop-dependencies
1.0.0-SNAPSHOT
../my-shop-dependencies/pom.xml
my-shop-web-ui
war
my-shop-web-ui
com.xue
my-shop-commons
${project.parent.version}

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-web-ui</module> 配置

my-shop-dependencies
my-shop-commons
my-shop-domain
my-shop-web-admin
my-shop-web-ui

 

创建接口模块

在my-shop工程下创建一个名为 my-shop-web-api 的项目,用于存放用到的应用程序接口及api的,并不是我们创建的interface,在其项目下创建pom.xml 文件如下:

4.0.0
com.xue
my-shop-dependencies
1.0.0-SNAPSHOT
../my-shop-dependencies/pom.xml
my-shop-web-api
war
my-shop-web-api
com.xue
my-shop-commons
${project.parent.version}

 

PS:别忘记在 my-shop 工程的 pom.xml 中增加 <module>my-shop-web-api</module> 配置

my-shop-dependencies
my-shop-commons
my-shop-domain
my-shop-web-admin
my-shop-web-ui
my-shop-web-api

 

好了,到此基本的架构已经搭建好了

 

转载于:https://www.cnblogs.com/yaoyaoling/p/9771033.html

你可能感兴趣的文章
javascript系列之DOM(二)
查看>>
awk使用
查看>>
函数放到onload里面,在html里面执行函数会报错-----作用域和闭包相关问题
查看>>
自学html--one(div布局)
查看>>
LCM ADN GCD
查看>>
C++之编译器与链接器工作原理
查看>>
Bootstrap: 样式CSS:carousel轮换 图片的使用
查看>>
new和new[]的区别
查看>>
读书笔记之《高效人士的七个习惯》
查看>>
VS2017 IIS 部署.net core web项目
查看>>
java虚拟机学习(一)
查看>>
Ubuntu部署jmeter
查看>>
P1064 金明的预算方案
查看>>
一文告诉你git如何使用
查看>>
linux常用命令(学习笔记)
查看>>
PJSIP-PJLIB-Socket
查看>>
[Gamma]Scrum Meeting#10
查看>>
selenium--等待的三种方式
查看>>
nautilus-open-terminal很有用的插件--鼠标右键打开终端
查看>>
android中自定义的dialog中的EditText无法弹出输入法解决方案
查看>>