当前位置:   article > 正文

1秒将本地SpringBoot项目jar包部署到Linux环境(看这一篇就够了)_如何部署jar包到linux服务器

如何部署jar包到linux服务器

目标

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

迭代步骤

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

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

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

例如:

image-20221212222543292

2、Window启动jar包

java -jar SpringBootTest-0.0.1-SNAPSHOT.jar
  • 1

image-20221212222726325

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

二、linux环境启动jar包

1、先将jar包扔到linux环境

image-20221212223047762

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

java -jar SpringBootTest-0.0.1-SNAPSHOT.jar 
  • 1

image-20221212223419188

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

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

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

nohup java -jar SpringBootTest-0.0.1-SNAPSHOT.jar > springboot.log 2>&1 &
  • 1
# 解释
# 'nohup': 用于在后台运行命令,并将其与当前终端会话脱离,即使关闭终端,命令也将继续在后台运行。
# '> springboot.log':此部分使用重定向操作符 > 将标准输出重定向到 springboot.log 文件中。程序的标准输出将被写入到 springboot.log 文件中,而不会在终端上显示。
# '2>&1':此部分使用重定向操作符 2>&1 将标准错误(stderr)重定向到标准输出(stdout),即将标准错误与标准输出一起写入到 springboot.log 文件中。
# '&':最后一个 & 操作符将命令置于后台运行,使得程序在后台持续运行,而不会阻塞当前终端会话。
  • 1
  • 2
  • 3
  • 4
  • 5

image-20221212224437149

启动成功,进程号为9777

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

image-20221212224900449

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

创建脚本

vim start.sh
  • 1

脚本内容

# 关闭程序
# 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 2>&1 &
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

之后,启动项目就可以

sh start.sh
  • 1

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

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

image-20221212230932820

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

image-20221212231306254

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

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

image-20221212231557682

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

image-20221212231701412

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

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

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

三、分离依赖部署

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

(1)创建lib文件夹

mkdir lib
  • 1

image-20221212234058558

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

image-20221212234121085

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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

image-20221212234306062

3.重新package

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

4.上传到服务器

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

image-20221212234731533

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

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

cp start.sh start2.sh
  • 1

(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 2>&1 &
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

使用外部依赖启动成功

image-20221213000012544

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

6.合并start.shstart2.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 $fileName > springboot.log 2>&1 &
else
  echo "文件大小为【$filesize】,使用外部依赖启动"
  nohup java -jar -Dloader.path=./lib $fileName > springboot.log 2>&1 &
fi
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

适配两种情况

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

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

image-20230612231840376

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

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

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

2、需要手动执行脚本

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

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

1、IDEA安装Alibaba Cloud Toolkit插件

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

image-20221213001348655

2.配置服务器地址

image-20221213001619732

image-20221213001829872

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

image-20221213001856838

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

查看所在路径

image-20221213002904012

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

image-20221213002141765

填加执行命令

image-20221213002232898

image-20221213003705741

4.点击Upload按钮

成果:1秒部署SpringBoot项目

image-20221213003608495

提示:由于该插件安装后会在IDEA的左右侧边栏出现好几个其他的功能按钮,可以将他们移除,只留下底下的上传功能。

操作方式:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/715433
推荐阅读
相关标签
  

闽ICP备14008679号