0

0

使用Gradle Shadow Jar插件构建包含所有依赖的可执行JAR包

心靈之曲

心靈之曲

发布时间:2025-10-31 15:04:11

|

564人浏览过

|

来源于php中文网

原创

使用Gradle Shadow Jar插件构建包含所有依赖的可执行JAR包

本文旨在解决gradle多模块项目中,如何将主模块及其所有依赖打包成一个可独立运行的“胖jar”(fat jar)文件的问题。通过引入`com.github.johnrengelman.shadow`插件,并配置主类信息,我们可以轻松生成一个包含所有运行时依赖的jar包,从而实现`java -jar`命令的便捷执行,极大地简化了应用程序的部署与分发。

在Gradle项目中,尤其是在采用settings.gradle进行多模块管理的复杂结构中,将一个模块及其所有外部依赖打包成一个可独立运行的JAR文件(通常称为“胖JAR”或“Uber JAR”)是一个常见的需求。默认的jar任务只会打包当前模块的代码,并不会包含其依赖项。这意味着,如果直接运行默认生成的JAR包,应用程序将因缺少必要的库而报错。为了解决这个问题,我们需要一个专门的工具来聚合所有依赖。

核心解决方案:使用Gradle Shadow Jar插件

com.github.johnrengelman.shadow插件,通常被称为Shadow Jar插件,是Gradle生态系统中用于创建包含所有依赖的可执行JAR包的强大工具。它能够将项目及其所有依赖项(包括传递性依赖)打包到一个单一的JAR文件中,同时处理潜在的类名冲突(例如,不同依赖中包含同名文件的情况)。

步骤一:在主模块中应用Shadow Jar插件

首先,你需要在希望生成可执行JAR包的主模块的build.gradle文件中应用Shadow Jar插件。请注意,settings.gradle主要用于定义项目结构和包含子模块,而具体的构建逻辑和插件应用则发生在各个模块的build.gradle文件中。

// 在你的主模块(例如,名为 'app' 的模块)的 build.gradle 文件中
plugins {
    id 'java' // 确保应用了Java插件
    id 'application' // 可选,但推荐,用于简化主类配置
    id 'com.github.johnrengelman.shadow' version '7.1.2' // 应用Shadow Jar插件,请使用最新稳定版本
}

// ... 其他配置,如 group, version, repositories, dependencies 等

// 配置应用程序的主类
application {
    // 定义应用程序的入口主类
    mainClass = 'jaso92559.app.App' // 替换为你的实际主类路径
}

// 可选:显式配置JAR文件的Manifest,与application块功能有重叠,
// 但在某些情况下可能需要,例如当不使用application插件时。
jar {
    manifest {
        attributes "Main-Class": "jaso92559.app.App" // 替换为你的实际主类路径
    }
}

配置说明:

  • id 'java': 这是Gradle项目的基本插件,用于构建Java应用程序。
  • id 'application': 这是一个方便的插件,它会自动创建一些任务(如run、distZip、distTar)并允许你通过application块配置应用程序的主类。Shadow Jar插件通常能很好地与application插件集成,自动识别mainClass。
  • id 'com.github.johnrengelman.shadow' version '7.1.2': 这是核心配置,应用Shadow Jar插件。请务必将version替换为当前最新的稳定版本。
  • application.mainClass: 指定了你的应用程序的入口点。这是java -jar命令执行时会调用的类。
  • jar.manifest.attributes "Main-Class": 这是一个传统的Java JAR清单文件配置,用于指定JAR包的主类。当使用application插件时,通常不需要手动配置此项,因为application插件会处理它。但作为一种显式配置,它也能确保主类被正确写入。

步骤二:执行Shadow Jar构建任务

在配置完成后,你可以在项目的根目录下(即settings.gradle文件所在的目录)打开命令行终端,执行Shadow Jar插件提供的构建任务:

./gradlew shadowJar

或者,如果你在Windows系统上:

ChatYoutube
ChatYoutube

Youtube视频总结器,一键分析以及对话

下载
gradlew shadowJar

Gradle将会编译你的代码,解析所有依赖,并将它们一并打包到一个新的JAR文件中。这个过程可能需要一些时间,具体取决于你的项目大小和依赖数量。

步骤三:定位并运行生成的JAR文件

构建成功后,生成的“胖JAR”文件通常位于主模块的build/libs目录下。它的命名规则通常是[模块名]-[版本号]-all.jar,例如app-all.jar。

你可以通过以下命令来运行它:

java -jar app/build/libs/app-all.jar

请将app/build/libs/app-all.jar替换为你的实际文件路径和名称。

注意事项与最佳实践:

  1. 插件版本管理: 始终使用Shadow Jar插件的最新稳定版本,以获取最新的功能和bug修复。你可以在其GitHub仓库或Gradle Plugin Portal上查找最新版本。
  2. 多模块项目中的应用: Shadow Jar插件通常只应用于需要作为独立应用程序分发的主模块。对于其他库模块,它们通常不需要生成“胖JAR”,而是作为依赖被主模块引用。
  3. JAR文件大小: 胖JAR文件会包含所有依赖,因此文件大小会显著增加。在某些场景下,这可能不是最佳选择(例如,Web应用程序通常打包为WAR或EAR,由应用服务器管理依赖)。
  4. 类名冲突处理: Shadow Jar插件在打包过程中会尝试处理类名冲突(例如,不同的依赖库中包含同名的META-INF/services文件)。它通常会合并或重命名这些资源,但复杂冲突仍需手动干预。
  5. 与java -cp的区别 使用java -jar运行胖JAR文件时,JVM会读取JAR包内部的META-INF/MANIFEST.MF文件中的Main-Class属性来启动应用程序。而java -cp(classpath)命令则需要你手动指定所有依赖的路径,这对于包含大量依赖的复杂项目来说非常繁琐,也是使用Shadow Jar插件的主要原因之一。

通过遵循上述步骤和最佳实践,你可以有效地使用Gradle Shadow Jar插件,为你的Java应用程序创建可独立运行、包含所有依赖的JAR包,从而简化应用程序的部署和分发流程。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

672

2023.06.15

java流程控制语句有哪些
java流程控制语句有哪些

java流程控制语句:1、if语句;2、if-else语句;3、switch语句;4、while循环;5、do-while循环;6、for循环;7、foreach循环;8、break语句;9、continue语句;10、return语句。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2024.02.23

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

722

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

725

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

394

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

441

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

427

2023.08.02

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2万人学习

C# 教程
C# 教程

共94课时 | 5.3万人学习

Java 教程
Java 教程

共578课时 | 37.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号