java模块化开发 maven_Maven 模块化开发

(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 中增加 my-shop-dependencies 配置

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 中增加 my-shop-commons 配置

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 中增加 my-shop-web-admin 配置

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 中增加 my-shop-web-admin 配置

my-shop-dependencies

my-shop-commons

my-shop-domain

my-shop-web-admin

注意

由于我们用的快照版,当工程或者某个项目的某个版本号更改了,这时候我们需要总是更新快照版,修改setting的mavenhttps%3A%2F%2Fnote.youdao.com%2Fyws%2Fpublic%2Fresource%2F9d617032f9b866baef0054a4104f4000%2Fxmlnote%2FCE2D848C71B94337AF518FCF06C2E7F7%2F10166

创建商城前端

在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 中增加 my-shop-web-ui 配置

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 中增加 my-shop-web-api 配置

my-shop-dependencies

my-shop-commons

my-shop-domain

my-shop-web-admin

my-shop-web-ui

my-shop-web-api

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

a2046572148bc52ebce684f742e47854.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值