闲扯Maven项目代码组织形式

开发 项目管理
如果使用这种操作流程,需要注意一点,就是每个模块代码更新之后,要及时安装到本地仓库,否则当 web 模块独立打包时,用到的其他模块就不是最新的代码。

[[428059]]

1. 代码组织形式

  • 1.1 平铺
  • 1.2 父子结构

2. 打包问题

  • 2.1 继承
  • 2.2 聚合

3. 小结

因为最近有小伙伴问到了,所以我想和大家随便扯扯 Maven 项目中代码的组织形式这个问题。

其实也不是啥大问题,但是如果不懂的话,就像雾里看花,始终不能看的明明白白,懂了就像一层窗户纸,捅破就好了。

所以我们就简单扯几句。

1. 代码组织形式

首先来说说代码组织形式。

一般来说,就两种比较常见的形式:

  • 平铺
  • 父子结构

这两种形式松哥在不同的项目中都有遇到过,所以我们就不说孰优孰劣,单纯来说这两种方案。

1.1 平铺

平铺的代码类似下面这样:

  1. ├── parent 
  2. │   ├── pom.xml 
  3. │   └── src 
  4. │       ├── main 
  5. │       │   ├── java 
  6. │       │   └── resources 
  7. │       └── test 
  8. │           └── java 
  9. ├── vhr-dao 
  10. │   ├── pom.xml 
  11. │   ├── src 
  12. │   │   ├── main 
  13. │   │   │   ├── java 
  14. │   │   │   └── resources 
  15. │   │   └── test 
  16. │   │       └── java 
  17. └── vhr-service 
  18.     ├── pom.xml 
  19.     ├── src 
  20.     │   ├── main 
  21.     │   │   ├── java 
  22.     │   │   └── resources 
  23.     │   └── test 
  24.     │       └── java 

如下图:

可以看到,在这种结构下,parent 父工程和各个子工程从代码组织形式上来看都是平级的,都处于同一个目录下。

不过仔细查看 pom.xml 文件,还是能够清晰的看到这三个 module 的父子关系的:

parent:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <modelVersion>4.0.0</modelVersion> 
  6.  
  7.     <groupId>org.javaboy</groupId> 
  8.     <artifactId>parent</artifactId> 
  9.     <packaging>pom</packaging> 
  10.     <version>1.0-SNAPSHOT</version> 
  11.     <modules> 
  12.         <module>../vhr-dao</module> 
  13.         <module>../vhr-service</module> 
  14.     </modules> 
  15.  
  16. </project> 

 

可以看到,在指定 module 时,由于 vhr-dao 和 vhr-service 和 parent 的 pom.xml 不在同一个目录下,所以这里使用了相对路径,相对路径的参考依据是 parent 的 pom.xml 文件位置。

vhr-dao:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <parent> 
  6.         <artifactId>parent</artifactId> 
  7.         <groupId>org.javaboy</groupId> 
  8.         <version>1.0-SNAPSHOT</version> 
  9.         <relativePath>../parent/pom.xml</relativePath> 
  10.     </parent> 
  11.     <modelVersion>4.0.0</modelVersion> 
  12.  
  13.     <artifactId>vhr-dao</artifactId> 
  14.  
  15.  
  16. </project> 

可以看到,relativePath 节点中,通过相对路径指定了 parent 的 pom.xml 文件位置,这个相对路径的参考依据是子模块的 pom.xml 文件。

vhr-service:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <parent> 
  6.         <artifactId>parent</artifactId> 
  7.         <groupId>org.javaboy</groupId> 
  8.         <version>1.0-SNAPSHOT</version> 
  9.         <relativePath>../parent/pom.xml</relativePath> 
  10.     </parent> 
  11.     <modelVersion>4.0.0</modelVersion> 
  12.  
  13.     <artifactId>vhr-service</artifactId> 
  14.  
  15.  
  16. </project> 

这个和 vhr-dao 的差不多,不赘述。

1.2 父子结构

父子结构则类似于下面这样:

  1. ├── maven_parent 
  2. │   ├── pom.xml 
  3. │   ├── vhr-dao 
  4. │   │   ├── pom.xml 
  5. │   │   └── src 
  6. │   │       ├── main 
  7. │   │       │   ├── java 
  8. │   │       │   └── resources 
  9. │   │       └── test 
  10. │   │           └── java 
  11. │   └── vhr-service 
  12. │       ├── pom.xml 
  13. │       └── src 
  14. │           ├── main 
  15. │           │   ├── java 
  16. │           │   └── resources 
  17. │           └── test 
  18. │               └── java 

如下图:

这种父子结构的看起来就非常的层次分明了,parent 和各个 module 一眼就能看出来,我们从 GitHub 上下载的很多开源项目如 Shiro,都是这种结构。

不过文件夹的层级并不能说明任何问题,关键还是要看 pom.xml 中的定义,接下来我们就来看看 parent 的 pom.xml 和各个子模块的 pom.xml 有何异同。

maven_parent:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <modelVersion>4.0.0</modelVersion> 
  6.  
  7.     <groupId>org.javaboy</groupId> 
  8.     <artifactId>maven_parent</artifactId> 
  9.     <packaging>pom</packaging> 
  10.     <version>1.0-SNAPSHOT</version> 
  11.     <modules> 
  12.         <module>vhr-dao</module> 
  13.         <module>vhr-service</module> 
  14.     </modules> 
  15.  
  16.  
  17. </project> 

 

 

和前面不同的是,这里声明 modules 不需要相对路径了(其实还是相对路径,只是不需要 ../ 了),因为各个子模块和 parent 的 pom.xml 文件处于同一目录下。

vhr-dao:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <parent> 
  6.         <artifactId>maven_parent</artifactId> 
  7.         <groupId>org.javaboy</groupId> 
  8.         <version>1.0-SNAPSHOT</version> 
  9.     </parent> 
  10.     <modelVersion>4.0.0</modelVersion> 
  11.  
  12.     <artifactId>vhr-dao</artifactId> 
  13.  
  14.  
  15. </project> 

 

这里也不需要通过 relativePath 节点去指定 parent 的 pom.xml 文件位置了,因为 parent 的 pom.xml 和各个子模块处于同一目录下。

vhr-service:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" 
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  5.     <parent> 
  6.         <artifactId>maven_parent</artifactId> 
  7.         <groupId>org.javaboy</groupId> 
  8.         <version>1.0-SNAPSHOT</version> 
  9.     </parent> 
  10.     <modelVersion>4.0.0</modelVersion> 
  11.  
  12.     <artifactId>vhr-service</artifactId> 
  13.  
  14.  
  15. </project> 

 

2. 打包问题

2.1 继承

有的时候,单纯只是想通过 parent 来统一管理不同的项目的依赖,并非一个聚合项目。

这个时候只需要去掉 parent 的 pom.xml 中的 modules 节点及其中的内容即可,这样就不是聚合工程了,各个子模块也可以独立打包。

2.2 聚合

当然很多情况我们是聚合工程。

聚合工程的话,一般松哥是建议大家从 parent 处统一进行打包:

这样可以确保打包到的是最新的代码。

当然还有另外一种操作流程:

  1. 首先将 parent 安装到本地仓库。
  2. 然后分别将 model、dao 以及 service 等模块安装到本地仓库。
  3. 最后 web 模块就可以独立打包了。

如果使用这种操作流程,需要注意一点,就是每个模块代码更新之后,要及时安装到本地仓库,否则当 web 模块独立打包时,用到的其他模块就不是最新的代码。

3. 小结

好啦,几个 Maven 中的小问题,窗户纸捅破了就豁然开朗啦~

本文转载自微信公众号「江南一点雨」,可以通过以下二维码关注。转载本文请联系江南一点雨生公众号。

 

责任编辑:武晓燕 来源: 江南一点雨
相关推荐

2022-08-03 14:21:00

Maven项目代码

2009-03-02 10:50:19

虚拟 项目 管理

2009-03-02 18:13:33

虚拟化虚拟管理计算机

2023-11-06 08:47:52

操作系统物理内存

2017-03-02 14:38:35

2023-05-09 16:04:44

2009-11-16 11:31:54

Oracle数据导入

2009-11-11 09:48:06

Visual Stud

2009-11-06 17:13:24

Oracle SQL语

2009-11-13 14:49:50

Visual StudWindows Azu

2009-11-12 11:00:56

Visual C++

2021-03-07 22:37:17

Go代码模式

2009-12-25 13:58:15

LINUX光标移动

2022-04-27 08:22:41

非代码形式开源开发者

2009-12-25 18:05:05

Linux压缩程式

2009-11-10 11:22:11

Visual Stud

2016-03-30 09:56:07

c语言变量声明objectivec

2020-03-30 11:30:52

微服务架构数据

2016-06-30 09:36:53

IT众包服务解放号中软国际

2009-12-29 13:22:17

点赞
收藏

51CTO技术栈公众号