zl程序教程

您现在的位置是:首页 >  Java

当前栏目

深入理解微服务Maven父子项目构造以及项目打包部署

2023-04-18 16:16:02 时间

一、问题背景

       随着微服务项目的越来越流行,更多的公司开始使用微服务来搭建自己的业务系统。微服务很好地解耦了业务,每一个服务只提供特定的功能,真正的做到了各司其职,互不干扰,同时微服务间可以互相通信,可以更好的互相协调并完成一条完整的业务逻辑。对于微服务来说,众多的子服意味着需要搭建很多子服务系统,这些子服务系统多而杂,给项目的打包编译以及开发带来了不小的挑战,但maven父子项目的出现很好的解决了这一弊端。

二、概念介绍

2.1 什么是maven父子项目

       顾名思义,maven父子项目是一个有一个父项目,父项目下面又有很多子项目的maven工程,当然,子项目下面还可以添加子项目,从而形成一个树形的结构。那么,这么做有什么好处呢?有以下两点:①依赖传递②打包方便

2.2 父子项目依赖关系

       (1) 所有的子项目依赖从父项目传递下来,子项目的pom文件不必重复添加依赖,直接使用父项目依赖的jar包即可。
举个栗子:父项目A的pom文件中依赖了fastjson2的依赖

<!-- https://mvnrepository.com/artifact/com.alibaba.fastjson2/fastjson2 -->
<dependency>
    <groupId>com.alibaba.fastjson2</groupId>
    <artifactId>fastjson2</artifactId>
    <version>2.0.15</version>
</dependency>

       那么作为子项目B,在其pom中不加fastjson2的依赖就可以直接使用fastjson2中的所有API方法了。当然,也可以不用父项目中的依赖,直接添加fastjson2的任何版本依赖,那么这时代码中使用的就是B项目中的依赖了。
       (2) 为了更好的管理jar包版本,可以在父项目pom文件中使用<dependencyManagement></dependencyManagement>标签将jar包管理起来,同时使用<properties></properties>将版本号管理起来。如下图:
在这里插入图片描述
在这里插入图片描述
使用dependencyManagement管理起来的jar包不会被父项目依赖,只是起到了一个版本管理的作用,当子项目需要使用依赖的时候需要添加依赖的groupId和artifactId,此时不需要指定version,自动从父类获取版本信息。

2.3 父子项目打包编译

       微服务子模块较多,如果把每一个项目来一遍打包编译不仅繁琐还浪费时间和精力,使用maven父子项目的结构,直接在父项目上运行打包命令,此时子项目会挨个打包编译,只需要等待一会儿,所有子项目的打包编译就完成了,非常方便。

2.3.1 胖包与瘦包

       胖包就是打成的jar包中包含了所有的依赖,而瘦包则是将项目中的源码打进jar包。瘦包没有指定主类,需要在使用时自行指定。胖包的体积往往特别大,少则八百十兆多则能达到2-3G,不仅占存储空间还给运维增加了成本,而瘦包体积小,往往只有几十kb,小巧轻便,运维也方便。

三、实战操作

3.1 创建maven父子工程

这里以idea为开发工具进行演示。

  1. 创建一个maven父工程
    在这里插入图片描述
  2. 一般情况下,父工程中不需要写代码,故删除src文件
    在这里插入图片描述
  3. 创建两个子工程,右键父工程,new→Module
    在这里插入图片描述
    4.至此,我们创建了两个子工程
    在这里插入图片描述
  4. 修改父工程pom文件,使用modules标签将子项目引入,同时修改packaging标签为pom
    在这里插入图片描述
  5. 子工程pom文件添加parent标签指明父工程,同时修改packaging标签为jar或者war,你会发现,子工程里面没有groupId,因为他们共用父工程的groupId。
    在这里插入图片描述
    到目前为止,我们已经成功的创建出maven父子工程了

3.2 胖瘦包打包

  1. 子工程pom引入maven-compiler-plugin 编译插件;
  2. 子工程pom引入maven-assembly-plugin插件,可个性化定制打包结构;
    <build>
        <!--jar包的首名称-->
        <finalName>son1</finalName>
        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>2.4</version>
                <configuration>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                    <archive>
                        <manifest>
                            <mainClass>com.king.Son1SpringApplication</mainClass><!--这里改成自己的启动位置(主类位置)-->
                        </manifest>
                    </archive>
                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>
                        <phase>package</phase>
                        <goals>
                            <goal>single</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
  1. 右键父工程maven package打包,可以看到一共生成了两个jar包,一个带依赖的一个不带依赖的,这就是胖包和瘦包。
    在这里插入图片描述

在这里插入图片描述

四、总结

       maven父子工程可以给我们的子系统管理、开发带来便捷,提高我们的开发效率,在以后的工作中希望大家能多使用这种工程结构。好了,本篇博文就写到这里,本人水平有限,如发现错误之处,还请各位大佬多多指正。😊😊😊