教你1秒將本地SpringBoot項(xiàng)目jar包部署到Linux環(huán)境(超詳細(xì)!)
目標(biāo)
一鍵將本地已經(jīng)打包好的SpringBoot項(xiàng)目部署到linux環(huán)境,實(shí)現(xiàn)秒級(jí)部署
前置知識(shí):需掌握Maven的打包
迭代步驟
- 在windows環(huán)境使用命令啟動(dòng)SpringBoot項(xiàng)目
- 在Linux環(huán)境使用命令啟動(dòng)項(xiàng)目
- 在Linux環(huán)境使用腳本啟動(dòng)項(xiàng)目
- 優(yōu)化腳本,每次重啟時(shí)先關(guān)閉項(xiàng)目
- 分離依賴(lài),每次上傳Linux環(huán)境只上傳幾百k的代碼包
- 搭配IDEA插件,實(shí)現(xiàn)在IDEA中一鍵部署
一、前提:
有一個(gè)Windows環(huán)境可以啟動(dòng)的SpringBoot項(xiàng)目jar包
1、使用Maven的package命令打出一個(gè)攜帶依賴(lài)的jar包
例如:
2、Window啟動(dòng)jar包
java -jar SpringBootTest-0.0.1-SNAPSHOT.jar
啟動(dòng)完畢,說(shuō)明jar包是可以正常啟動(dòng)的。
二、linux環(huán)境啟動(dòng)jar包
1、先將jar包扔到linux環(huán)境
2、測(cè)試是否可以啟動(dòng)(需要有Java環(huán)境)
java -jar SpringBootTest-0.0.1-SNAPSHOT.jar
說(shuō)明在Linux環(huán)境也是可以正常啟動(dòng)的
但是以上的啟動(dòng)方式有個(gè)問(wèn)題,窗口一關(guān)項(xiàng)目就自動(dòng)關(guān)閉了
3、優(yōu)化啟動(dòng)腳本,改為后臺(tái)啟動(dòng),并將日志輸出到springboot.log
nohup java -jar SpringBootTest-0.0.1-SNAPSHOT.jar > springboot.log &
啟動(dòng)成功,進(jìn)程號(hào)為9777
以上的腳本也存在問(wèn)題,第二次啟動(dòng)的時(shí)候,會(huì)因?yàn)橐呀?jīng)啟動(dòng)了一個(gè)服務(wù),端口占用啟動(dòng)不了
4、完善腳本,啟動(dòng)時(shí),如果存在已經(jīng)啟動(dòng)的服務(wù),先關(guān)閉,再啟動(dòng)
創(chuàng)建腳本
vim start.sh
腳本內(nèi)容
# 關(guān)閉程序 # fileName為jar包的名稱(chēng) fileName=SpringBootTest-0.0.1-SNAPSHOT.jar pid=$(ps -ef | grep $fileName| grep -v "grep" | awk '{print $2}') kill -9 $pid # 啟動(dòng)項(xiàng)目 nohup java -jar $fileName > springboot.log &
之后,啟動(dòng)項(xiàng)目就可以
sh start.sh
至此,SpringBoot項(xiàng)目在Linux的啟動(dòng)就說(shuō)明完畢。
但是,以上的部署方式還存在一些問(wèn)題,在只有web依賴(lài)的時(shí)候,jar的大小就已經(jīng)達(dá)到17M,
而在實(shí)際開(kāi)發(fā)中,jar包的大小甚至?xí)竭_(dá)一百多兆。例如這樣:
為什么明明沒(méi)有多少代碼,包的大小卻這么大呢?
解壓SpringBootTest-0.0.1-SNAPSHOT.jar包查看內(nèi)容
可以看出,lib文件夾占用了16.7M,而lib文件夾里面是什么東西呢?
可以看到,就是各種的依賴(lài)。
所以,就引發(fā)了新的優(yōu)化方向,能不能將依賴(lài)包直接放在服務(wù)器上,每次只更新自己的代碼?
答案是:可以!在實(shí)際開(kāi)發(fā)中,依賴(lài)包一般來(lái)說(shuō)是不會(huì)動(dòng)的,于是開(kāi)始第三步。
三、分離依賴(lài)部署
1.上傳依賴(lài)jar包Linux服務(wù)器
(1)創(chuàng)建lib文件夾
mkdir lib
(2)將jar包中的/BOOT-INF/lib
目錄底下的jar包全部上傳到Linux服務(wù)器的lib文件夾
2.改造項(xiàng)目的pom.xml文件
增加配置:
<build> <plugins> <!-- 解決jar中沒(méi)有主清單屬性問(wèn)題 --> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <mainClass>com.example.springboottest.SpringBootTestApplication</mainClass> <!-- jar包不攜帶依賴(lài)配置開(kāi)始--> <layout>ZIP</layout> <includes> <include> <groupId>nothing</groupId> <artifactId>nothing</artifactId> </include> </includes> <!-- jar包不攜帶依賴(lài)部署配置結(jié)束--> </configuration> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
3.重新package
新生成的jar包僅僅只有156kb!
4.上傳到服務(wù)器
這時(shí)候,如果使用原本的腳本啟動(dòng)就會(huì)報(bào)錯(cuò):
5.使用-Dloader.path指定外部依賴(lài)包
(1)增加啟動(dòng)文件start2.sh
cp start.sh start2.sh
(2)在java -jar后追加-Dloader.path=./lib
# 關(guān)閉程序 fileName=SpringBootTest-0.0.1-SNAPSHOT.jar pid=$(ps -ef | grep $fileName| grep -v "grep" | awk '{print $2}') kill -9 $pid # 啟動(dòng)項(xiàng)目 nohup java -jar -Dloader.path=./lib $fileName > springboot.log &
使用外部依賴(lài)啟動(dòng)成功
到此,使用外部依賴(lài)啟動(dòng)就完成了,只要加上
-Dloader.path=./lib
就可以了
6.合并start.sh和start2.sh腳本
第五步還存在的一個(gè)問(wèn)題,雖然這個(gè)方法很好用,但是又增加了一個(gè)腳本。公司內(nèi)部,總是有人想要打全量包,使用自帶的依賴(lài),有的人想要打不攜帶依賴(lài)的包,可以快速部署啟動(dòng),這時(shí)候,就需要區(qū)分,到底是要用
start.sh
腳本還是start2.sh
腳本,于是,將start.sh
和start2.sh
腳本進(jìn)行合并,大于10M的時(shí)候,就使用內(nèi)部依賴(lài),小于10M的時(shí)候就使用外部依賴(lài)
合并后的start.sh腳本:
# 關(guān)閉程序 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(fèi)以上使用外部依賴(lài) maxsize=$((1024 * 1024 * 10)) # 10M if [ $filesize -gt $maxsize ] then echo "文件大小為【$filesize】,使用內(nèi)部依賴(lài)啟動(dòng)" nohup java -jar -Dloader.path=./lib $fileName > springboot.log & else echo "文件大小為【$filesize】,使用外部依賴(lài)啟動(dòng)" nohup java -jar $fileName > springboot.log & fi
適配兩種情況
小于10M的jar包使用外部依賴(lài)
大于10M的jar包使用內(nèi)部依賴(lài)
在第三步優(yōu)化完之后,jar包的大小大大減少,只剩下1M都不到,每次上傳耗時(shí)不到1s,還能不能繼續(xù)優(yōu)化呢?
答案也是可以!當(dāng)前還存在的問(wèn)題是:
1、需要手動(dòng)選擇文件上傳。
2、需要手動(dòng)執(zhí)行腳本
于是,進(jìn)行第四步優(yōu)化,引入Alibaba Cloud Toolkit插件
四、搭配Alibaba Cloud Toolkit插件使用,實(shí)現(xiàn)一鍵上傳文件,并執(zhí)行腳本
1、IDEA安裝Alibaba Cloud Toolkit插件
1.1 從插件市場(chǎng)中下載Alibaba Cloud Toolkit插件,并重啟IDEA。
2.配置服務(wù)器地址
可以看到就增加了一條新的配置
3.配置上傳地址和執(zhí)行的命令
查看所在路徑
點(diǎn)擊上傳,配置上傳的文件、上傳地址以及執(zhí)行的腳本
填加執(zhí)行命令
4.點(diǎn)擊Upload按鈕
成果:1秒部署SpringBoot項(xiàng)目
總結(jié)
到此這篇關(guān)于將本地SpringBoot項(xiàng)目jar包部署到Linux環(huán)境的文章就介紹到這了,更多相關(guān)SpringBoot項(xiàng)目jar包部署到Linux內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java通過(guò)自定義類(lèi)加載器實(shí)現(xiàn)類(lèi)隔離
類(lèi)隔離是一種通過(guò)類(lèi)加載器實(shí)現(xiàn)加載所需類(lèi)的實(shí)現(xiàn)方式,使得不同版本類(lèi)間隔離,避免了使用沖突問(wèn)題。本文將通過(guò)自定義的類(lèi)加載器實(shí)現(xiàn)類(lèi)隔離,感興趣的可以了解一下2022-08-08Java中的NoSuchMethodException異常原因以及解決方案詳解
這篇文章主要介紹了Java中的NoSuchMethodException異常原因以及解決方案詳解,NoSuchMethodException是Java反射機(jī)制中的異常,在嘗試通過(guò)反射獲取方法時(shí),找不到指定的方法,通常發(fā)生在調(diào)用?Class?對(duì)象的方法時(shí),當(dāng)方法名或方法參數(shù)不匹配時(shí)拋出該異常,需要的朋友可以參考下2024-02-02IDEA導(dǎo)入Springboot項(xiàng)目,注解和pom文件不識(shí)別的解決
這篇文章主要介紹了IDEA導(dǎo)入Springboot項(xiàng)目,注解和pom文件不識(shí)別的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04springmvc @ResponseStatus和ResponseEntity的使用
這篇文章主要介紹了springmvc @ResponseStatus和ResponseEntity的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07Spring 開(kāi)發(fā)之組件賦值的實(shí)現(xiàn)方法
這篇文章主要介紹了Spring 開(kāi)發(fā)之組件賦值的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09在SSM中配置了事務(wù)控制但沒(méi)生效的問(wèn)題
這篇文章主要介紹了在SSM中配置了事務(wù)控制但沒(méi)生效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02Java集合排序規(guī)則接口Comparator用法解析
這篇文章主要介紹了Java集合排序規(guī)則接口Comparator用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09