当前位置: 首页 > news >正文

SpringBoot项目打jar包自定义名称完全指南

SpringBoot项目打jar包自定义名称完全指南

前言

作为一名Java开发者,你是否遇到过这样的困扰:SpringBoot项目打包后生成的jar文件名又长又复杂,比如my-project-1.0.0-SNAPSHOT.jar?部署时总是要记住这个复杂的文件名,既不方便也容易出错。

今天我们就来学习如何给SpringBoot项目的jar包起一个简洁明了的名字!

问题场景

默认情况下,Maven打包SpringBoot项目时,生成的jar文件名格式为:

{artifactId}-{version}.jar

例如,如果你的项目配置是:

<groupId>com.example</groupId>
<artifactId>my-springboot-app</artifactId>
<version>1.0.0</version>

那么打包后的文件名就是:my-springboot-app-1.0.0.jar

但在实际开发中,我们可能希望jar包有一个更简洁、更有意义的名字,比如:app.jarspring-admin.jar

解决方案:使用finalName

Maven提供了<finalName>标签来自定义最终生成的文件名。

基本用法

在项目的pom.xml文件中,找到<build>节点,添加<finalName>配置:

<build><finalName>spring-admin</finalName><!-- 其他配置... -->
</build>

完整示例

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"><modelVersion>4.0.0</modelVersion><groupId>com.jbolt</groupId><artifactId>jbolt_ai_platform_springboot</artifactId><version>2.5.0</version><name>spring-admin</name><build><!-- 自定义打包后的文件名 --><finalName>spring-admin</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><mainClass>cn.jbolt.JBoltAIPlatformApplication</mainClass></configuration></plugin></plugins></build>
</project>

操作步骤

步骤1:修改pom.xml

  1. 打开项目根目录下的pom.xml文件
  2. 找到<build>标签(如果没有就创建一个)
  3. <build>标签内添加<finalName>你想要的名字</finalName>

步骤2:重新打包

保存pom.xml文件后,执行Maven打包命令:

# 方式1:使用Maven命令
mvn clean package# 方式2:如果使用Maven Wrapper
./mvnw clean package# 方式3:在IDE中运行
# 右键项目 -> Run As -> Maven build -> 输入 clean package

步骤3:查看结果

打包完成后,在项目的target目录下,你会看到生成的jar文件名已经变成你指定的名字了!

target/
├── spring-admin.jar          ← 这就是我们自定义的名字
├── spring-admin.jar.original ← 原始jar包(不包含依赖)
└── 其他文件...

原理解释

finalName的作用机制

  • <finalName>标签告诉Maven在打包时使用指定的名字
  • 这个配置会影响所有类型的打包结果(jar、war、zip等)
  • SpringBoot的maven插件会在此基础上生成可执行的jar包

文件说明

打包后你会看到两个jar文件:

  1. spring-admin.jar - 可执行的"Fat JAR",包含了所有依赖,可以直接运行
  2. spring-admin.jar.original - 原始jar包,只包含项目代码,不包含依赖

我们部署时使用的是第一个文件。

高级用法

1. 动态命名

你可以在finalName中使用Maven属性:

<properties><app.name>my-app</app.name><deploy.env>prod</deploy.env>
</properties><build><finalName>${app.name}-${deploy.env}</finalName>
</build>

这样会生成:my-app-prod.jar

2. 包含版本信息

<build><finalName>${project.name}-v${project.version}</finalName>
</build>

3. 时间戳命名

<properties><maven.build.timestamp.format>yyyyMMdd-HHmm</maven.build.timestamp.format>
</properties><build><finalName>app-${maven.build.timestamp}</finalName>
</build>

实际应用场景

场景1:微服务项目

在微服务架构中,每个服务都可以有一个简洁的名字:

<!-- 用户服务 -->
<finalName>user-service</finalName><!-- 订单服务 -->
<finalName>order-service</finalName><!-- 网关服务 -->
<finalName>gateway</finalName>

场景2:不同环境部署

<!-- 开发环境 -->
<finalName>app-dev</finalName><!-- 生产环境 -->
<finalName>app-prod</finalName>

场景3:Docker部署

<finalName>app</finalName>

对应的Dockerfile:

FROM openjdk:8-jre-slim
COPY target/app.jar /app.jar
ENTRYPOINT ["java", "-jar", "/app.jar"]

注意事项

1. 文件名规范

  • 建议使用小写字母和连字符
  • 避免使用空格和特殊字符
  • 保持名字简洁有意义

2. 部署脚本适配

如果你有自动化部署脚本,记得更新脚本中的文件名:

# 旧的脚本
java -jar my-springboot-app-1.0.0.jar# 新的脚本
java -jar spring-admin.jar

3. CI/CD流水线

在Jenkins、GitLab CI等流水线中,也要相应更新文件路径。

常见问题

Q1: finalName会影响项目的其他配置吗?

A: 不会。finalName只影响最终生成的文件名,不会影响项目的groupId、artifactId等Maven坐标。

Q2: 可以在不同的profile中使用不同的finalName吗?

A: 可以的!

<profiles><profile><id>dev</id><build><finalName>app-dev</finalName></build></profile><profile><id>prod</id><build><finalName>app-prod</finalName></build></profile>
</profiles>

Q3: 如果不想要版本号,但想保留原项目名怎么办?

A: 可以使用Maven属性:

<finalName>${project.artifactId}</finalName>

总结

通过使用Maven的<finalName>配置,我们可以轻松地为SpringBoot项目的jar包自定义名称。这个小技巧虽然简单,但在实际项目中非常有用,能够:

  1. 简化部署流程 - 不用记住复杂的文件名
  2. 提高可读性 - 文件名更有意义
  3. 统一命名规范 - 团队协作更顺畅
  4. 便于自动化 - 脚本和CI/CD更容易维护

现在就去试试吧!给你的SpringBoot项目起一个好听的名字~

参考资料

  • Maven官方文档 - Build Configuration
  • Spring Boot官方文档 - Build Tool Plugins

💡 小提示:这个技巧不仅适用于SpringBoot项目,对于所有使用Maven构建的Java项目都有效!

相关文章:

  • 02 C语言程序设计之导言
  • 嵌入式学习笔记 - freeRTOS任务栈在初始化以及任务切换时的压栈出栈过程分析
  • OpenEMMA: 打破Waymo闭源,首个开源端到端多模态模型
  • [手写系列]从0到1开发并上线Edge浏览器插件
  • 硬件工程师笔记——555定时器应用Multisim电路仿真实验汇总
  • 【使用】【经验】docker 清理未使用的镜像的命令
  • Ubuntu安装Docker命令清单(以20.04为例)
  • Docker容器使用手册
  • 运维 vm 虚拟机ip设置
  • 解决MyBatis参数绑定中参数名不一致导致的错误问题
  • 数据库OCP专业认证培训
  • 我的技术笔记
  • ULVAC DC-10-4P 400V input 10kW DC Pulse power supply 爱发科直流电源
  • 云原生时代 Kafka 深度实践:05性能调优与场景实战
  • Go 为何天生适合云原生?
  • 深入解析 Flask 命令行工具与 flask run命令的使用
  • Flask 应用的生产环境部署指南
  • 环境对象以及回调函数
  • Cursor + Claude 4:海外工具网站开发变现实战案例
  • Linux(线程概念)
  • 查企业法人信息查询平台/seo优化工具哪个好
  • 新时代推进政府网站集约化建设/网络营销的特点分别是
  • 新手怎么做网站打理/宁宁网seo
  • 一个网站有个前端后端怎么做/推广普通话
  • 东阿县住房和城乡建设局网站/国内新闻最新
  • 网站流量功能更怎么做/seo优质友链购买