Java项目Ubuntu编译打包步骤
Ubuntu下Ja va项目编译与打包步骤

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
在Ubuntu环境下搞定Ja va项目的编译和打包,其实没那么复杂。关键在于把环境搭对,然后根据你的项目特点,选对工具和方法。下面这份手把手的指南,涵盖了从基础环境配置到进阶打包方案的全过程,帮你避开那些常见的坑。
一 准备环境
万事开头难,但环境配置这一步,只要按顺序来,其实很简单。核心就两件事:装好JDK,再选一个趁手的构建工具。
- 安装 JDK(建议 OpenJDK 11 或更高版本):
- 打开终端,一条命令就能搞定安装:
sudo apt update && sudo apt install openjdk-11-jdk。这条命令会先更新软件包列表,然后安装指定版本的JDK。 - 装完之后,别忘了验证一下。分别输入
ja va -version和ja vac -version,看看输出的版本号是不是你刚装的。这一步能帮你确认环境变量是否配置正确。
- 打开终端,一条命令就能搞定安装:
- 安装构建工具(二选一或都装):
- Ma ven:如果你习惯用Ma ven,安装命令是
sudo apt install ma ven。验证安装成功同样用版本命令:mvn -v。 - Gradle:喜欢Gradle的灵活性?那就用
sudo apt install gradle来安装。安装后执行gradle -v进行验证。
- Ma ven:如果你习惯用Ma ven,安装命令是
- 环境齐备后,建议准备一个有入口类的项目结构来测试。最快捷的方式是使用Ma ven原型生成一个简单项目:
mvn archetype:generate -DgroupId=com.example -DartifactId=my-app -DarchetypeArtifactId=ma ven-archetype-quickstart -DinteractiveMode=false。这个命令会在当前目录生成一个标准的Ma ven项目骨架,里面自带一个可执行的示例主类。
二 使用Ma ven打包
对于Ma ven项目,打包过程已经高度标准化。你只需要在包含pom.xml文件的根目录下操作。
- 执行核心打包命令:
mvn clean package。这个命令会先清理旧的构建产物,然后执行编译、测试,最终打包。- 打包生成的JAR文件默认位于
target/目录下,名字通常是项目名-版本号.jar。 - 不过,默认打出来的JAR可能不可直接运行。这就需要一些常用插件与配置来增强:
- 编译器插件:用于指定Ja va源码和目标字节码的版本,确保兼容性。
org.apache.ma ven.plugins ma ven-compiler-plugin 3.8.1 11 11 - 可执行 JAR:使用
ma ven-jar-plugin在清单文件中指定主类,这样打出来的JAR才能用ja va -jar运行。org.apache.ma ven.plugins ma ven-jar-plugin 3.2.0 true lib/ com.example.App - 依赖外置:把项目依赖的第三方库单独复制到
target/lib目录,可以让主JAR包体积更小,更新更灵活。这需要配合上面manifest中设置的classpathPrefix=lib/使用。org.apache.ma ven.plugins ma ven-dependency-plugin 3.2.0 copy-dependencies package copy-dependencies ${project.build.directory}/lib
- 编译器插件:用于指定Ja va源码和目标字节码的版本,确保兼容性。
- 打包生成的JAR文件默认位于
- 配置妥当后,再次运行
mvn clean package,就能在target/下得到可执行的JAR。运行它只需:ja va -jar target/你的项目名.jar。
三 使用Gradle打包
Gradle的打包逻辑同样清晰,其配置写在build.gradle文件中,风格更偏向脚本化。
- 在项目根目录执行构建命令:
./gradlew clean build(如果系统已全局安装Gradle,也可用gradle clean build)。- 打包产物位于
build/libs/目录下。 - 要让JAR可执行,需要在
build.gradle中进行一些基本配置:plugins { id 'ja va' id 'application' } sourceCompatibility = '11' mainClassName = 'com.example.App' repositories { ma venCentral() } dependencies { testImplementation 'junit:junit:4.13.2' } jar { manifest { attributes 'Main-Class': mainClassName } } - 同样,你也可以实现依赖外置,将运行时依赖库复制到指定目录,便于管理。
task copyDependencies(type: Copy) { from configurations.runtimeClasspath into 'build/libs/lib' } build.dependsOn copyDependencies
- 打包产物位于
- 执行
./gradlew build后,使用ja va -jar build/libs/xxx.jar即可运行程序。
四 无构建工具与进阶打包
除了Ma ven和Gradle,还有一些场景需要更直接或更高级的打包方式。
- 手动编译与打包(适合学习或小项目)
- 这种方式能让你透彻理解JAR包的构成。首先,编译源码:
ja vac -d out src/com/example/*.ja va,-d out指定了编译输出目录。 - 接着,在
src目录同级创建一个MANIFEST.MF文件,内容至少包含:Manifest-Version: 1.0 Main-Class: com.example.App - 最后,使用
jar命令打包:jar cfm my-app.jar MANIFEST.MF -C out .。参数cfm分别表示创建文件、指定清单文件、指定主类入口。 - 运行:
ja va -jar my-app.jar。
- 这种方式能让你透彻理解JAR包的构成。首先,编译源码:
- 使用 jpackage 生成平台原生可执行安装包(JDK 14+)
- 这是Ja va提供的一个强大工具,可以直接生成.exe、.dmg或.deb/.rpm等安装包。一个基本示例:
jpackage --type app-image --input target --name myapp --main-class com.example.App --output out。它会创建一个包含应用和精简JRE的镜像。
- 这是Ja va提供的一个强大工具,可以直接生成.exe、.dmg或.deb/.rpm等安装包。一个基本示例:
- 使用 jlink 定制精简运行时(JDK 9+,适用于模块化项目)
- 如果你的项目是模块化的,可以用jlink裁剪出一个只包含所需模块的JRE,显著减小分发体积。命令示例:
jlink --module-path $JA VA_HOME/jmods:mods --add-modules ja va.base,ja va.logging,your.module.name --output custom-jre。
- 如果你的项目是模块化的,可以用jlink裁剪出一个只包含所需模块的JRE,显著减小分发体积。命令示例:
- 使用 Docker 打包发布
- 容器化部署已成为主流。一个典型的多阶段构建Dockerfile示例如下:
这个Dockerfile先在一个包含完整JDK的镜像中构建项目,再将生成的JAR文件复制到一个更小的只包含JRE的镜像中运行,兼顾了构建需求与运行镜像的体积。FROM openjdk:11-jdk-slim AS builder WORKDIR /app COPY . . RUN ./gradlew build FROM openjdk:11-jre-slim WORKDIR /app COPY --from=builder /app/build/libs/app.jar /app/app.jar EXPOSE 8080 CMD ["ja va","-jar","/app/app.jar"] - 构建与运行命令:
docker build -t myapp .构建镜像;docker run -p 8080:8080 myapp运行容器。
- 容器化部署已成为主流。一个典型的多阶段构建Dockerfile示例如下:
相关攻略
Ubuntu FTP服务器配置指南:实现FTPS与SFTP加密文件传输 在Ubuntu系统上部署FTP服务器时,确保数据传输过程的安全性是关键环节。未加密的FTP连接可能导致敏感信息泄露,因此采用加密传输协议至关重要。目前,主流的解决方案有两种:FTPS(基于SSL TLS的FTP)和SFTP(基于
关于系统安全威胁的客观探讨 在网络安全领域,针对特定系统编写或利用漏洞的行为,不仅触及法律红线,也严重违背了普遍的道德准则。因此,本文将聚焦于对常见网络攻击手段的客观梳理,并分析包括Ubuntu在内的系统可能面临的普遍性威胁,旨在提升认知而非提供技术细节。 常见的网络攻击手段 网络威胁的形式多种多样
在Ubuntu中配置Python环境变量,其实就这么几步 对于刚接触Linux的开发者来说,配置环境变量有时会让人有点摸不着头脑。别担心,这事儿其实比想象中简单。下面这张图可以帮你快速建立起一个直观的印象: 接下来,我们聊聊几种主流且可靠的方法。你可以根据自己系统的具体情况,选择最顺手的一种。 方法
Ubuntu下Python性能优化路线图 想让Ubuntu上的Python应用跑得更快?这事儿其实有章可循。下面这份路线图,就为你梳理了从环境准备到系统部署的全链路优化思路,帮你一步步榨干性能潜力。 一 基线与环境准备 优化这事儿,得先打好地基。几个核心动作,能让你后续的调优事半功倍。 解释器是根本
在 Ubuntu 上,Python 的安装路径通常位于 usr bin python 或 usr local bin python 那么,如何快速定位到你系统里 Python 的确切位置呢?方法其实很简单,打开终端,敲入下面这个命令就行: which python 当然,你也可以试试另一个同样好
热门专题
热门推荐
红色沙漠腾空刺击稳定触发方法 想在《红色沙漠》里稳定打出帅气的腾空刺击吗?这个技能的关键,在于精准把握那个“完全浮空”的瞬间。简单说,就是在二段跳的最高点,角色身体还在空中、没有任何落地趋势时,按下Shift+右键(PC)或对应的手柄键位。下面这几种方法,能帮你把成功率拉到最高。 基础稳法 这套操作
红色沙漠疾风斩观摩位置介绍 想在《红色沙漠》里耍出帅气的疾风斩,第一步不是急着去点技能,而是先“看会了”。这就好比学书法,总得先看看名家是怎么运笔的。游戏里提供了非常直观的观摩机会,让你能把释放时机和节奏看得清清楚楚。 疾风斩观摩位置 核心观摩点就在主城埃尔南德。具体位置,是城东北侧的警卫队训练场,
《杀戮尖塔2》中的战术基石:计划妥帖状态详解 在《杀戮尖塔2》的复杂战局中,手牌管理往往是决定胜负的关键。而“计划妥帖”这个可叠加的状态,正是为此而生的核心机制。简单来说,它允许你在每回合结束时,将指定数量的关键卡牌“扣在手里”,带入下一回合。这为那些依赖特定卡牌组合、需要精准规划跨回合战术的构筑,
解放《红色沙漠》恺利恩采石场:从清场到斩首的完整战术指南 面对恺利恩采石场那根顽固的100%占领进度条,很多人的第一反应是埋头清怪。但经验告诉我们,和无穷无尽的小兵硬耗,效率实在太低。真正的突破口,在于那三个带着醒目红色标记的关键建筑。拆掉它们,整个战场的难度会陡然降低。 红色沙漠恺利恩采石场解放方
山寨币如何快速查询市场深度与挂单情况? 对于山寨币交易而言,市场深度与挂单情况绝非可有可无的背景信息,它们直接决定了你交易的滑点大小、成交效率乃至买卖时机。尤其是在那些成交量偏小或波动剧烈的代币上,能否快速读懂订单簿和深度图,几乎成了区分普通玩家与精明交易者的分水岭。接下来,我们就来梳理几种高效的查





