您的位置:首页 >Java项目Ubuntu编译打包步骤
发布于2026-04-25 阅读(0)
扫一扫,手机访问

在Ubuntu环境下搞定Ja va项目的编译和打包,其实没那么复杂。关键在于把环境搭对,然后根据你的项目特点,选对工具和方法。下面这份手把手的指南,涵盖了从基础环境配置到进阶打包方案的全过程,帮你避开那些常见的坑。
万事开头难,但环境配置这一步,只要按顺序来,其实很简单。核心就两件事:装好JDK,再选一个趁手的构建工具。
sudo apt update && sudo apt install openjdk-11-jdk。这条命令会先更新软件包列表,然后安装指定版本的JDK。ja va -version和ja vac -version,看看输出的版本号是不是你刚装的。这一步能帮你确认环境变量是否配置正确。sudo apt install ma ven。验证安装成功同样用版本命令:mvn -v。sudo apt install gradle来安装。安装后执行gradle -v进行验证。mvn archetype:generate -DgroupId=com.example -DartifactId=my-app -DarchetypeArtifactId=ma ven-archetype-quickstart -DinteractiveMode=false。这个命令会在当前目录生成一个标准的Ma ven项目骨架,里面自带一个可执行的示例主类。对于Ma ven项目,打包过程已经高度标准化。你只需要在包含pom.xml文件的根目录下操作。
mvn clean package。这个命令会先清理旧的构建产物,然后执行编译、测试,最终打包。
target/目录下,名字通常是项目名-版本号.jar。
org.apache.ma ven.plugins
ma ven-compiler-plugin
3.8.1
11
11
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
mvn clean package,就能在target/下得到可执行的JAR。运行它只需:ja va -jar target/你的项目名.jar。Gradle的打包逻辑同样清晰,其配置写在build.gradle文件中,风格更偏向脚本化。
./gradlew clean build(如果系统已全局安装Gradle,也可用gradle clean build)。
build/libs/目录下。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,还有一些场景需要更直接或更高级的打包方式。
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。jpackage --type app-image --input target --name myapp --main-class com.example.App --output out。它会创建一个包含应用和精简JRE的镜像。jlink --module-path $JA VA_HOME/jmods:mods --add-modules ja va.base,ja va.logging,your.module.name --output custom-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"]
这个Dockerfile先在一个包含完整JDK的镜像中构建项目,再将生成的JAR文件复制到一个更小的只包含JRE的镜像中运行,兼顾了构建需求与运行镜像的体积。
docker build -t myapp . 构建镜像;docker run -p 8080:8080 myapp 运行容器。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9