教你1秒将本地SpringBoot项目jar包部署到Linux环境(超详细!)

目录
  • 目标
  • 迭代步骤
  • 一、前提:
    • 1、使用Maven的package命令打出一个携带依赖的jar包
    • 2、Window启动jar包
  • 二、linux环境启动jar包
    • 1、先将jar包扔到linux环境
    • 2、测试是否可以启动(需要有Java环境)
    • 3、优化启动脚本,改为后台启动,并将日志输出到springboot.log
    • 4、完善脚本,启动时,如果存在已经启动的服务,先关闭,再启动
  • 三、分离依赖部署
    • 1.上传依赖jar包Linux服务器
    • 2.改造项目的pom.xml文件
    • 3.重新package
    • 4.上传到服务器
    • 5.使用-Dloader.path指定外部依赖包
    • 6.合并start.sh和start2.sh脚本
  • 四、搭配Alibaba Cloud Toolkit插件使用,实现一键上传文件,并执行脚本
    • 1、IDEA安装Alibaba Cloud Toolkit插件
    • 2.配置服务器地址
    • 3.配置上传地址和执行的命令
  • 总结

目标

一键将本地已经打包好的SpringBoot项目部署到linux环境,实现秒级部署
前置知识:需掌握Maven的打包

迭代步骤

  • 在windows环境使用命令启动SpringBoot项目
  • 在Linux环境使用命令启动项目
  • 在Linux环境使用脚本启动项目
  • 优化脚本,每次重启时先关闭项目
  • 分离依赖,每次上传Linux环境只上传几百k的代码包
  • 搭配IDEA插件,实现在IDEA中一键部署

一、前提:

有一个Windows环境可以启动的SpringBoot项目jar包

1、使用Maven的package命令打出一个携带依赖的jar包

例如:

2、Window启动jar包

java -jar SpringBootTest-0.0.1-SNAPSHOT.jar

启动完毕,说明jar包是可以正常启动的。

二、linux环境启动jar包

1、先将jar包扔到linux环境

2、测试是否可以启动(需要有Java环境)

java -jar SpringBootTest-0.0.1-SNAPSHOT.jar 

说明在Linux环境也是可以正常启动的

但是以上的启动方式有个问题,窗口一关项目就自动关闭了

3、优化启动脚本,改为后台启动,并将日志输出到springboot.log

nohup java -jar SpringBootTest-0.0.1-SNAPSHOT.jar > springboot.log &

启动成功,进程号为9777

以上的脚本也存在问题,第二次启动的时候,会因为已经启动了一个服务,端口占用启动不了

4、完善脚本,启动时,如果存在已经启动的服务,先关闭,再启动

创建脚本

vim start.sh

脚本内容

# 关闭程序
# fileName为jar包的名称
fileName=SpringBootTest-0.0.1-SNAPSHOT.jar
pid=$(ps -ef | grep $fileName| grep -v "grep" | awk '{print $2}')
kill -9 $pid

# 启动项目
nohup java -jar $fileName > springboot.log &

之后,启动项目就可以

sh start.sh

至此,SpringBoot项目在Linux的启动就说明完毕。

但是,以上的部署方式还存在一些问题,在只有web依赖的时候,jar的大小就已经达到17M,

而在实际开发中,jar包的大小甚至会到达一百多兆。例如这样:

为什么明明没有多少代码,包的大小却这么大呢?

解压SpringBootTest-0.0.1-SNAPSHOT.jar包查看内容

可以看出,lib文件夹占用了16.7M,而lib文件夹里面是什么东西呢?

可以看到,就是各种的依赖。

所以,就引发了新的优化方向,能不能将依赖包直接放在服务器上,每次只更新自己的代码?

答案是:可以!在实际开发中,依赖包一般来说是不会动的,于是开始第三步。

三、分离依赖部署

1.上传依赖jar包Linux服务器

(1)创建lib文件夹

mkdir lib

(2)将jar包中的/BOOT-INF/lib目录底下的jar包全部上传到Linux服务器的lib文件夹

2.改造项目的pom.xml文件

增加配置:

    <build>
        <plugins>
            <!-- 解决jar中没有主清单属性问题 -->
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.example.springboottest.SpringBootTestApplication</mainClass>
                    <!-- jar包不携带依赖配置开始-->
                    <layout>ZIP</layout>
                    <includes>
                        <include>
                            <groupId>nothing</groupId>
                            <artifactId>nothing</artifactId>
                        </include>
                    </includes>
                    <!-- jar包不携带依赖部署配置结束-->
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

3.重新package

新生成的jar包仅仅只有156kb!

4.上传到服务器

这时候,如果使用原本的脚本启动就会报错:

5.使用-Dloader.path指定外部依赖包

(1)增加启动文件start2.sh

cp start.sh start2.sh

(2)在java -jar后追加-Dloader.path=./lib

# 关闭程序
fileName=SpringBootTest-0.0.1-SNAPSHOT.jar
pid=$(ps -ef | grep $fileName| grep -v "grep" | awk '{print $2}')
kill -9 $pid

# 启动项目
nohup java -jar -Dloader.path=./lib  $fileName > springboot.log &

使用外部依赖启动成功

到此,使用外部依赖启动就完成了,只要加上-Dloader.path=./lib就可以了

6.合并start.sh和start2.sh脚本

第五步还存在的一个问题,虽然这个方法很好用,但是又增加了一个脚本。公司内部,总是有人想要打全量包,使用自带的依赖,有的人想要打不携带依赖的包,可以快速部署启动,这时候,就需要区分,到底是要用start.sh脚本还是start2.sh脚本,于是,将start.shstart2.sh脚本进行合并,大于10M的时候,就使用内部依赖,小于10M的时候就使用外部依赖

合并后的start.sh脚本:

# 关闭程序
fileName=SpringBootTest-0.0.1-SNAPSHOT.jar
pid=$(ps -ef | grep $fileName| grep -v "grep" | awk '{print $2}')
kill -9 $pid

# 获取jar包的大小
filesize=`ls -l $fileName | awk '{ print $5 }'`
# 多少M以上使用外部依赖
maxsize=$((1024 * 1024 * 10)) # 10M

if [ $filesize -gt $maxsize ]
then
  echo "文件大小为【$filesize】,使用内部依赖启动"
  nohup java -jar -Dloader.path=./lib  $fileName > springboot.log &
else
  echo "文件大小为【$filesize】,使用外部依赖启动"
  nohup java -jar $fileName > springboot.log &
fi

适配两种情况

小于10M的jar包使用外部依赖

大于10M的jar包使用内部依赖

在第三步优化完之后,jar包的大小大大减少,只剩下1M都不到,每次上传耗时不到1s,还能不能继续优化呢?

答案也是可以!当前还存在的问题是:

1、需要手动选择文件上传。

2、需要手动执行脚本

于是,进行第四步优化,引入Alibaba Cloud Toolkit插件

四、搭配Alibaba Cloud Toolkit插件使用,实现一键上传文件,并执行脚本

1、IDEA安装Alibaba Cloud Toolkit插件

1.1 从插件市场中下载Alibaba Cloud Toolkit插件,并重启IDEA。

2.配置服务器地址

可以看到就增加了一条新的配置

3.配置上传地址和执行的命令

查看所在路径

点击上传,配置上传的文件、上传地址以及执行的脚本

填加执行命令

4.点击Upload按钮

成果:1秒部署SpringBoot项目

总结

到此这篇关于将本地SpringBoot项目jar包部署到Linux环境的文章就介绍到这了,更多相关SpringBoot项目jar包部署到Linux内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解docker部署SpringBoot及替换jar包的方法

    关于docker的安装和使用,可以看看之前这两篇文章.docker kubernetes dashboard安装部署详细介绍和Docker如何使用link建立容器之间的连接.这篇文章主要介绍如何在docker上部署springboot项目.关于如何创建springboot项目可以看看这篇文章IDEA上面搭建一个SpringBoot的web-mvc项目遇到的问题 本文主要介绍docker部署springboot的三种方式,分别是:入门方式.jar包替换部署的方式和脚本部署方式,一步步来手把手教程.

  • 详解springboot中的jar包部署步骤

    eclipse中: 1.单击整个项目 run as - maven clean - maven install 2.找到项目所在的路径 找到所有的jar包 3.把jar包放到linux对应的文件夹 linux中部署项目: 1.查看jar是否在运行中 ps -ef | grep SpliderWeb-0.0.1-SNAPSHOT.jar 2.有运行的jar包 杀死对应的进程 kill 进程号 3.无运行的jar包 部署项目 java -jar SpliderWeb-0.0.1-SNAPSHOT.j

  • spring boot 部署为jar包的方法示例

    前言 一直在ide中敲代码,使用命令行 mvn spring-boot:run 或者 gradlew bootRun 来运行spring boot项目.想来放到prod上面也应该很简单.然而今天试了下,各种问题.最大错误是1.4的bug: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jp

  • SpringBoot中jar打包并部署到Tomcat

    1.详细步骤 首先在pom.xml文件中做一些修改: 之前打war包需要修改打包方式,这次不需要了,因为默认就是 jar 包指定最终打成jar包的名称手动指定 resources 文件夹编译打包的路径添加SpringBoot内嵌Tomcat解析jsp的依赖(仅仅是为这个实例而添加) <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/

  • 使用SpringBoot打jar包并部署到Tomcat详细步骤

    详细步骤 首先在pom.xml文件中做一些修改: 之前打war包需要修改打包方式,这次不需要了,因为默认就是 jar 包指定最终打成jar包的名称手动指定 resources 文件夹编译打包的路径添加SpringBoot内嵌Tomcat解析jsp的依赖(仅仅是为这个实例而添加) <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/PO

  • SpringBoot项目部署到服务器上的方法(Jar包)

    1. 部署方式 Springboot 和普通web 应用程序不一样,其本质上是一个 Java 应用程序,那么又如何部署呢?  通常来说,Springboot 部署会采用两种方式:全部打包成一个jar,或者打包成一个war.现在讲一下打包成 jar 部署. 2. 打包成 jar 第一种方法(idea) 1. clean 2. package 第二种方法(命令行): 键盘输入 windows + r : cd 命令切换到你项目所在路径: online 是我的项目名称,这里换成你自己的,可以看到当前是

  • Spring Boot打包war jar 部署tomcat

    概述 1.Spring Boot聚合工程打包war部署Tomcat 2.Spring Boot打包Jar,通过Java -jar直接运行. 3.提供完整pom.xml测试项目 至github 解决问题 1.xxxx中没有主清单属性 2.解决没有web.xml而报错 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-war-plugin:2.2:war (default-war) on project provider: E

  • 简单了解springboot的jar包部署步骤

    由于springboot常用war包部署,改为cloud开发模式多端口情况下,部署反而不习惯 毕竟,war包要不要项目名访问都必须放在tomcat的root目录下 而此目录限制只能放置一个项目,并且登录端口限制为tomcat的接口了 因此,jar包部署就成了必然的方式了 1.添加pom设置 静态文件需要访问,所以静态文件webapp下的文件需要重新指定位置,具体配置如下 <resource> <directory>src/main/webapp</directory>

  • springboot工程jar包部署到云服务器的方法

    首先,springboot在这里不多做介绍了,关于怎么打成jar包,我相信凡是用过的同学都知道吧! 然后就是将jar包上传到云服务器了,这个有好些工具的,博主在这里也不多做说明了! 咱们还是直奔主题吧.... 运行命令:java -jar xxx.jar,然后springboot工程的内置tomcat就开启了,项目已经启动,接下来你就可以访问了. 感觉一切ok,其实你已经掉到坑里了... 怎么回事呢? 当你关闭当前的xshell 命令界面时,再次访问就失效了,why? why? why? 这是因

  • 教你1秒将本地SpringBoot项目jar包部署到Linux环境(超详细!)

    目录 目标 迭代步骤 一.前提: 1.使用Maven的package命令打出一个携带依赖的jar包 2.Window启动jar包 二.linux环境启动jar包 1.先将jar包扔到linux环境 2.测试是否可以启动(需要有Java环境) 3.优化启动脚本,改为后台启动,并将日志输出到springboot.log 4.完善脚本,启动时,如果存在已经启动的服务,先关闭,再启动 三.分离依赖部署 1.上传依赖jar包Linux服务器 2.改造项目的pom.xml文件 3.重新package 4.上

  • SpringBoot项目Jar包如何瘦身部署的实现

    一.背景 SpringBoot 为我们快速开发提供了很好的架子,使得我们只需要少量配置就能开始我们的开发工作,但是当我们需要打包上传部署时,却是很神伤的一个问题,因为打出来的 Jar 包少则十几兆,多则一百来兆,我们需要上传至公网服务器时,是非常慢的,这就引出了今天的主题,SpringBoot项目Jar包如何瘦身部署 1.思路分析 jar,我们可以看出,jar 包里面分为以下三个模块 分为 BOOT-INF,META-INF,org 三个部分,打开 BOOT-INF 可以看到有 classes,

  • SpringBoot项目War包部署无法注册到Nacos中的解决

    目录 SpringBoot项目War包部署无法注册到Nacos中 问题 解决方案 SpringBoot项目war包部署及出现的问题 1.修改pom文件 2.在启动类或者配置类中继承SpringBootServletInitializer SpringBoot项目War包部署无法注册到Nacos中 注: 其实标题的描述不是很准确,准确的说是已经注册成功并且可以正常访问,但是在服务列表却看不到. 问题 最近在进行Eureka迁移Nacos架构升级的时候,发现有两个之前的旧项目,虽然也是SpringB

  • SpringBoot测试配置属性与web启动环境超详细图解

    目录 加载测试专用的属性 运行结果 使用外部bean对测试 运行结果 测速类启动web环境 我们在测试类中 运行结果 加载测试专用的属性 点开@SpringBootTest源码中查看 可以在之后加入临时配置, 也可以使用命令行args参数设置.设置的测试专用参数会覆盖配置文件中的. package com; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Value; i

  • 将本地SpringBoot项目发布到云服务器的方法

    如何将本地的SpringBoot项目发布到云服务器 环境.准备 一台云服务器(我的是linux系统) 一个能运行的SpringBoot项目 xsheel或者连接云服务器的软件 编辑器IDEA 首先对本地的项目打包成jar包 1.配置打包项目的依赖 在主pom.xml里添加 <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>

  • SpringBoot项目jar发布后如何获取jar包所在目录路径

    目录 SpringBoot项目jar发布获取jar包所在目录路径 SpringBoot打可执行jar运行时输出文件路径问题 SpringBoot项目jar发布获取jar包所在目录路径 ApplicationHome ah = new ApplicationHome(getClass()); File file = ah.getSource(); System.out.println(file.getParentFile().toString()); 说明: 该种方法获取jar包所在路径好处,会根

  • Tomcat启动springboot项目war包报错:启动子级时出错的问题

    今天公司springboot项目准备部署到测试服务器上进行测试,打包好war后放到tomcat里面启动后,前端文件能访问到,但是接口请求一直是404,一直找了很久的原因,tomcat启动是成功的,war打包的时候也提示build success了,tomcat启动日志发现报错: java.lang.IllegalStateException: 启动子级时出错   at org.apache.catalina.core.ContainerBase.addChildInternal(Containe

  • springboot项目idea热部署的教程详解

    1.添加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> <scope>true</scope> </dependency> 2.开启自动编译 3.ctrl+shifi+alt

随机推荐