Maven Shade Plugin is a Maven plugin that allows us to build uber-jars. In a nutshell, uber-jar are .jar files that, besides containing the source code of the application, also contain the dependencies that the application is using. From there, it helps us to build Java applications that can run standalone.
For example, I have a Maven project with a simple main class, when running, it will display the words “Hello from Huong Dan Java” as follows:
1 2 3 4 5 6 7 8 9 10 |
package com.huongdanjava.mavenshadeplugin; import org.apache.commons.lang3.StringUtils; public class Application { public static void main(String[] args) { System.out.println(StringUtils.capitalize("hello from Huong Dan Java")); } } |
In this example, I have used the commons-lang3 library to capitalize the first letter of this text.
1 2 3 4 5 |
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.12.0</version> </dependency> |
Result when running the application:
Now, I will declare to use Maven Shade Plugin to build this application that can run standalone:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>com.huongdanjava.mavenshadeplugin.Application</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> |
Here, I have configured to run the Maven Shade Plugin when we build the application with the “package” phase. At that time, Maven Shade Plugin will run the goal “shade” to package our source code with the dependencies it is using. I also configure resources transformer for Maven Shade Plugin with ManifestResourceTransformer that allows us to define a mainClass in the META-INF/MANIFEST.MF file of the jar file, making the jar file after building, can run standalone.
Well, there is a note that Maven Shade Plugin only works with Java from version 7 and up! You can configure your Maven project as follows to be able to use the Maven Shade Plugin:
1 2 3 4 |
<properties> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> |
This is because I use Java 8.
Now, if you run Maven build with the goal “clean package” for this project, then open Terminal on Linux/macOS or Console on Windows, go to the project’s target directory, run the command: “java -jar maven-shade -plugin-example-0.0.1-SNAPSHOT.jar”, you will see the following results:
As you can see, although I use the commons-lang3 library for my application, I don’t need to declare the classpath to this library at all. That’s because this library is already included in the maven-shade-plugin-example-0.0.1-SNAPSHOT.jar file!
You can also define some other information in the META-INF/MANIFEST.MF file inside the jar file, by configuring the Maven Shade Plugin as follows:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <manifestEntries> <Specification-Title>${project.artifactId}</Specification-Title> <Specification-Version>${project.version}</Specification-Version> <Implementation-Title>${project.artifactId}</Implementation-Title> <Implementation-Version>${project.version}</Implementation-Version> <Implementation-Vendor-Id>${project.groupId}</Implementation-Vendor-Id> </manifestEntries> <mainClass>com.huongdanjava.mavenshadeplugin.Application</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> |
At this point, rebuild the project, extract the jar file, you will see the META-INF/MANIFEST.MF file with similar content as follows:
1 2 3 4 5 6 7 8 9 10 11 |
Manifest-Version: 1.0 Archiver-Version: Plexus Archiver Created-By: Apache Maven 3.6.3 Built-By: khanh Build-Jdk: 15.0.1 Main-Class: com.huongdanjava.mavenshadeplugin.Application Implementation-Title: maven-shade-plugin-example Implementation-Vendor-Id: com.huongdanjava Implementation-Version: 0.0.1-SNAPSHOT Specification-Title: maven-shade-plugin-example Specification-Version: 0.0.1-SNAPSHOT |