Springboot项目打包成jar运行2种方式

简介: Springboot项目打包成jar运行2种方式

最近公司有个项目需要移植到SpringBoot框架上,项目里面又有许多第三方jar包,在linux服务器上最方便的就是用jar的方式来运行SpringBoot项目了,因此我研究了2种打jar包的方式,记录如下,供大家参考:


1、通过maven插件,将所有依赖包都打包成一个jar包,然后通过java -jar xxx.jar方式运行


由于项目中有些jar包是第三方的,maven官方仓库没有,需要使用mvn install命令打包到本地,然后将其写入到pom.xml的依赖中,maven仓库有的jar包则从maven官网找到对应版本的depdency写入pom文件里面,这样maven打包就可以包含第三方jar包了,否则maven只会打包pom文件里面的,不会包括第三方jar包,程序运行将报错。这里推荐2种打包第三方jar包的方式:


第一种:打包第三方jar包到本地仓库,然后在pom.xml中引入


例如:将alipay-sdk-abc.jar 打包到本地仓库


mvn命令:

‪mvn install:install-file -Dfile=‪G:\thirdpartyjar\alipay-sdk-abc.jar -DgroupId=com.thirdparty -DartifactId=alipay-sdk-abc -Dversion=3.1.0.8 -Dpackaging=jar


pom.xml配置:


<dependency>
    <groupId>com.thirdparty</groupId>
    <artifactId>alipay-sdk-abc</artifactId>
    <version>3.1.0.8</version>
</dependency>


然后在cmd或者IDEAterminal里面使用mvn clean package -X命令清理、打包成jar文件,-X命令可以看到具体的打包输出,便于分析。


这里用到了2plugin,一个是普通的maven插件用于将各种jar包打包到一起,可是这样的jar包是无法运行的,因为jar包里面没有启动类信息,还需要SpringBootmaven插件进行repackage,这样生成的jar包就包含启动信息,才可以运行,关键配置如下:


<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.5.1</version>
    <configuration>
    <source>1.8</source>
    <target>1.8</target>
    <compilerArgs>
    <!-- 过期的方法的警告-->
    <arg>-Xlint:deprecation</arg>
    </compilerArgs>
    <compilerArguments>
    <!-- 是否输出所有的编译信息(包括类的加载等)-->
    <!--<verbose />-->
    <!-- 解决maven命令编译报错,因为rt.jar 和jce.jar在jre的lib下面,不在jdk的lib下面,
导致maven找不到(java7以后会出现这个问题),将这2个jar包拷贝到jdk的lib下面估计也好使-->
        <bootclasspath>${java.home}/lib/rt.jar;${java.home}/lib/jce.jar</bootclasspath>
    </compilerArguments>
</configuration>
</plugin>
<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <executions>
        <execution>
            <goals>
                <goal>repackage</goal>
            </goals>
        </execution>
    </executions>
</plugin>


第二种:通过在pom.xml中指定第三方jar包路径来引入依赖


比如第三方jar包在lib文件夹下,对pom.xml的配置如下:


<dependencies>标签里面引入第三方jar包的依赖


pom.basedir指的是pom文件所在的目录,


systemPath指的是第三方jar包所在路径。


<dependency>
        <groupId>com.abc</groupId>
        <artifactId>cryptokit</artifactId>
        <version>1.0</version>
        <scope>system</scope>
        <systemPath>${pom.basedir}/lib/cryptokit-1.0.jar</systemPath>
 </dependency>

还必须修改<plugins>标签里面的maven plugin,增加includeSystemScope属性并设置为true

<plugin>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-maven-plugin</artifactId>
     <configuration>
           <includeSystemScope>true</includeSystemScope>
      </configuration>
</plugin>


第二种方式相比第一种方式,省事、方便。

 

2、将主程序打成jar包,然后和其他依赖jar包放在一起(包括maven下载的和第三方jar包),这样也可以通过java -jar xxx.jar方式运行


jar方式运行的前提是主程序jar包中的META-INF文件夹下的MANIFEST.MF文件必须有正确的Class-PathMain-Class


Class-Path指定了主程序依赖的jar,若配置错误,运行jar时将报ClassNotFoundException若新增或删除了一些jar包,需要删除该文件,并重新生成。

Main-Class指定了程序的运行入口,这里配置成SpringBoot的主函数。

MANIFEST.MF文件若配置不当,运行jar时将报xxxxxx.jar中没有主清单属性

MANIFEST.MF示例如下:


Manifest-Version: 1.0
Class-Path: spring-expression-4.3.20.RELEASE.jar jboss-logging-3.3.2.F
 inal.jar jcl-over-slf4j-1.7.25.jar SADK-CMBC-3.1.0.8.jar slf4j-api-1.
 7.25.jar spring-boot-starter-web-1.5.17.RELEASE.jar spring-webmvc-4.3
 .20.RELEASE.jar spring-boot-starter-tomcat-1.5.17.RELEASE.jar spring-
 aop-4.3.20.RELEASE.jar spring-boot-1.5.17.RELEASE.jar spring-boot-sta
 rter-logging-1.5.17.RELEASE.jar spring-core-4.3.20.RELEASE.jar snakey
 aml-1.17.jar tomcat-embed-websocket-8.5.34.jar spring-beans-4.3.20.RE
 LEASE.jar spring-boot-autoconfigure-1.5.17.RELEASE.jar log4j-over-slf
 4j-1.7.25.jar hibernate-validator-5.3.6.Final.jar classmate-1.3.4.jar
  spring-web-4.3.20.RELEASE.jar jul-to-slf4j-1.7.25.jar logback-classi
 c-1.1.11.jar spring-context-4.3.20.RELEASE.jar spring-boot-starter-1.
 5.17.RELEASE.jar jackson-databind-2.8.11.2.jar jackson-annotations-2.
 8.0.jar tomcat-annotations-api-8.5.34.jar tomcat-embed-el-8.5.34.jar
 jackson-core-2.8.11.jar logback-core-1.1.11.jar tomcat-embed-core-8.5
 .34.jar validation-api-1.1.0.Final.jar
Main-Class: com.example.testmaven.TestmavenApplication


3、IDEA打包步骤


3.1打包多个jar包


按Ctrl+Alt+Shift+S打开项目配置,点击Atrifacts,然后按如下截图进行:





点击testmaven.jar,可以看到Main ClassClass Path都有内容了:




src下也生成了META-INFO文件夹和MAINFEST.MF文件:



构建Artifacts:



点击Build或者Rebuild后将在对应文件下生成artifacts文件,里面有依赖的jar包和主程序包;


 


文件夹地址栏输入cmd来打开cmd


 

然后输入java -jar testmaven.jar,就能正确运行Spring Boot项目了:



3.2 使用maven打包成一个jar包


3.2.1 使用maven工具栏打包项目


通过点击view-tool windows -maven projects显示maven侧边栏



点击maven projects侧边栏,展开Lifecycle,第一步先双击clean按钮进行清理,该步会删除之前打包的文件夹。第二步双击package,进行打包操作,需要等待一段时间。




target下的红色框圈出的就是最终的目标jar:


 

3.2.2 使用maven命令打包并运行项目


(1)按Alt+F12打开Terminal;

(2)输入 mvn clean package;该命令首先清理了target文件夹,然后进行打包。等待一段时间后,打包完毕。

(3)输入cd target 进入jar包文件夹;

 (4) 输入java -jar xxxxx.jar 运行jar包。

相关文章
|
4天前
|
Java Maven
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
这篇文章详细介绍了构建SpringBoot项目的过程,包括新建工程、选择环境配置、添加依赖、项目结构说明,并演示了如何编写一个简单的Controller控制器实现输出功能,最后讲解了如何使用Maven将项目打包成可执行的JAR包,并提供了运行JAR包的命令和测试效果。
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
|
4天前
|
SQL 前端开发 Java
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
这篇文章介绍了如何在IntelliJ IDEA中使用Maven将Spring Boot项目打包成可运行的jar包,并提供了运行jar包的方法。同时,还讨论了如何解决jar包冲突问题,并提供了在IDEA中同时启动Vue前端项目和Spring Boot后端项目的步骤。
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
|
7天前
|
Java Docker 容器
SpringBoot Jar 包太大 瘦身 【终极版】
SpringBoot Jar 包太大 瘦身 【终极版】
27 1
|
5天前
|
Java Linux Nacos
Java -jar 运行 报 MalformedInputException: Input length = 1
Java -jar 运行 报 MalformedInputException: Input length = 1
6 0
|
7天前
|
Java
SpringBoot Jar 包太大 瘦身 【初试】
SpringBoot Jar 包太大 瘦身 【初试】
8 0
|
22天前
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
145 2
[JarEditor]可直接修改jar包的IDEA插件
|
19天前
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
24天前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
1月前
|
监控 Ubuntu Java
如何在Ubuntu上运行Jar包?
【7月更文挑战第9天】
58 0
如何在Ubuntu上运行Jar包?

热门文章

最新文章