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系统上:

Videoleap
Videoleap

Videoleap是一个一体化的视频编辑平台

下载
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包,从而简化应用程序的部署和分发流程。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

469

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.12.06

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

1073

2026.01.21

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

810

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1129

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

804

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2355

2023.08.08

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

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

精品课程

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

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 8万人学习

Java 教程
Java 教程

共578课时 | 53.7万人学习

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

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