暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Java选手必看打包插件:maven-shade-plugin和maven-assembly-plugin

大数据从业者 2020-09-11
4266


概述

    目前项目开发过程中用的管理工具主要有Maven、Gradle、sbt等。先说下sbt吧,这玩意我用的不是太多,只是在写scala代码的项目时候用过。Gradle只知道有些apache开源项目用了,比如Kafka等,不过本人一直没用过。其实,个人感觉,平时java选手用的最多的还是Maven。说到Maven,别的这里就不说了,不得不提的一点就是打包插件的使用。

    我用过的有两个:maven-assembly-plugin和maven-shade-plugin。这两个都可以用于将程序和依赖打成一个uber-jar,尤其是开发sparkstreaming、flink程序,往yarn上提交任务的时候。有时候一个程序实现很简单,但是依赖jar处理不好,会浪费很多时间和精力。


shade和assembly区别

     maven-assembly-plugin插件会将依赖和资源文件都打入最终的Jar包,诸如properties文件等。如果项目和依赖中都有相同名称的资源文件时,就会发生冲突,导致项目中的相同名称的文件不会打到最终的Jar包中。如果这个文件是一个关键的配置文件,便会导致问题。而maven-shade-plugin不存在这样的问题。所以,实际开发项目时候,还是尽量选用maven-shade-plugin吧。


maven-assembly-plugin案例

    <project>
    [...]
    <build>
    [...]
    <plugins>
    <plugin>
    <artifactId>maven-assembly-plugin</artifactId>
    <version>3.3.0</version>
    <configuration>
    <descriptorRefs>
    <descriptorRef>jar-with-dependencies</descriptorRef>
    </descriptorRefs>
    </configuration>
    <executions>
    <execution>
    <id>make-assembly</id> <!-- this is used for inheritance merges -->
    <phase>package</phase> <!-- bind to the packaging phase -->
    <goals>
    <goal>single</goal>
    </goals>
    </execution>
    </executions>
    </plugin>
    [...]
    </project>


    maven-shade-plugin案例

      <project>
      ...
      <build>
      <plugins>
      <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-shade-plugin</artifactId>
      <version>3.2.4</version>
      <configuration>
      <!-- put your configurations here -->
      </configuration>
      <executions>
      <execution>
      <phase>package</phase>
      <goals>
      <goal>shade</goal>
      </goals>
      </execution>
      </executions>
      </plugin>
      </plugins>
      </build>
      ...
      </project>


      结论

      当然都是使用如下命令打包

        mvn package

        首选maven-shade-plugin插件,对应的输出jar格式如下:

          target/sample-1.0.jar

          而maven-assembly-plugin插件,对应的输出jar格式如下:

            target/sample-1.0-jar-with-dependencies.jar


            文章转载自大数据从业者,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

            评论