IDEA Spring Boot 自動(dòng)化構(gòu)建+部署的實(shí)現(xiàn)
本文所有操作都基于Alibaba cloud Toolkit進(jìn)行操作。
1.插件安裝
在插件市場(chǎng)中下載安裝。
- 在IntelliJ IDEA頂部菜單欄中選擇File>Settings。
在Settings對(duì)話框的左側(cè)導(dǎo)航欄中單擊Plugins。
在Plugins區(qū)域單擊Marketplace。
在搜索欄中輸入Alibaba Cloud Toolkit。
Search Results區(qū)域會(huì)出現(xiàn)Alibaba Cloud Toolkit,單擊Install。

等待下載、安裝完成后,單擊Restart IDE。
填寫邀請(qǐng)碼

邀請(qǐng)碼:6ERULV
2.配置服務(wù)器地址
添加服務(wù)器。
在IntelliJ IDEA頂部菜單欄中選擇Tools>Alibaba Cloud>Alibaba Cloud View>Host。
在彈出的Host頁簽中單擊Add Host。

在Add Host對(duì)話框中設(shè)置Host List、Username、Password和Tag等參數(shù),完成后單擊 Add。
完成參數(shù)設(shè)置后,可以單擊Test Connection來測(cè)試是否能成功連接服務(wù)器。
3.部署應(yīng)用
在IntelliJ IDEA頂部菜單中選擇Alibaba Cloud>Deploy to Host...。
在Deploy to Host對(duì)話框設(shè)置部署參數(shù),然后單擊Run。

部署參數(shù)說明如下表所示:
參數(shù)
描述
File
- Maven Build:若當(dāng)前工程采用Maven構(gòu)建,可以直接構(gòu)建并部署。
- Upload File:若當(dāng)前工程不是采用Maven構(gòu)建,或在本地已存在打包好的部署文件,可以選擇并上傳本地的部署文件。
- Gradle Build:若當(dāng)前工程采用Gradle構(gòu)建,選擇此項(xiàng)來構(gòu)建并部署。
Target Host
在下拉列表中選擇Tag,然后在該Tag中選擇要部署的服務(wù)器。
Target Directory
輸入在服務(wù)器上的部署路徑,如/root/tomcat/webapps。
Command
輸入應(yīng)用啟動(dòng)命令,如sh /root/restart.sh。
3.如果出現(xiàn)如下圖,就說明文件正在上傳中

表示已經(jīng)上傳完畢

另外在附送一個(gè)啟動(dòng)|重啟腳本
#!/bin/bash
#這里可替換為jar包名字
APP_NAME=xxx-1.0.jar
#根據(jù)實(shí)際情況修改參數(shù)
JVM="-server -Xms2g -Xmx2g -Xmn512m -XX:PermSize=128M -XX:MaxNewSize=128m -XX:MaxPermSize=25zh6m -Xss256k -Djava.awt.headless=true -XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled -Xloggc:/logs/xxx-server/GC/xxx-gc.log"
#APPFILE_PATH="-Dspring.config.location=/usr/local/config/application.properties"
#使用說明,用來提示輸入?yún)?shù)
usage() {
echo "Usage: sh 執(zhí)行腳本.sh [start|stop|restart|status|log|backup]"
exit 1
}
#檢查程序是否在運(yùn)行
is_exist(){
pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' `
#如果不存在返回1,存在返回0
if [ -z "${pid}" ]; then
return 1
else
return 0
fi
}
#啟動(dòng)方法
start(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is already running. pid=${pid} ."
else
#nohup java $JVM -jar $APPFILE_PATH $APP_NAME > /dev/null 2>&1
#后臺(tái)啟動(dòng)jar包,且控制環(huán)境變量,根據(jù)實(shí)際情況修改吧。
nohup java $JVM -jar $APP_NAME --spring.profiles.active=prod > /dev/null 2>&1 &
fi
}
#停止方法
stop(){
is_exist
if [ $? -eq "0" ]; then
kill -9 $pid
else
echo "${APP_NAME} is not running"
fi
}
#輸出運(yùn)行狀態(tài)
status(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is running. Pid is ${pid}"
else
echo "${APP_NAME} is NOT running."
fi
}
#重啟
restart(){
stop
start
}
#日志
log(){
# 輸出實(shí)時(shí)日志
tail -n 100 -f /logs/fdc-server/fdc-server.log
}
#備份
backup(){
#根據(jù)需求自定義備份文件路徑。
BACKUP_PATH=/usr/local/webapps/backup/xxx-server/
#獲取當(dāng)前時(shí)間作為備份文件名
BACKUP_DATE=`date +"%Y%m%d(%H:%M:%S)"`
echo 'backup file ->'$BACKUP_PATH$BACKUP_DATE'.jar'
#備份當(dāng)前jar包
cp -r /usr/local/webapps/$APP_NAME $BACKUP_PATH$BACKUP_DATE'.jar'
}
#根據(jù)輸入?yún)?shù),選擇執(zhí)行對(duì)應(yīng)方法,不輸入則執(zhí)行使用說明
case "$1" in
"start")
start
;;
"stop")
stop
;;
"status")
status
;;
"restart")
restart
;;
"log")
log
;;
"backup")
backup
;;
*)
usage
;;
esac
到此這篇關(guān)于IDEA Spring Boot 自動(dòng)化構(gòu)建+部署的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)IDEA Spring Boot 自動(dòng)化構(gòu)建內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring注解實(shí)現(xiàn)Bean自動(dòng)裝配示例詳解
這篇文章主要給大家介紹了關(guān)于Spring注解實(shí)現(xiàn)Bean自動(dòng)裝配的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
Spring Boot 開發(fā)私有即時(shí)通信系統(tǒng)(WebSocket)
本文利用Spring Boot作為基礎(chǔ)框架,Spring Security作為安全框架,WebSocket作為通信框架,實(shí)現(xiàn)點(diǎn)對(duì)點(diǎn)聊天和群聊天2017-04-04
@Transactional注解:多個(gè)事務(wù)嵌套時(shí),獨(dú)立事務(wù)處理方式
這篇文章主要介紹了@Transactional注解:多個(gè)事務(wù)嵌套時(shí),獨(dú)立事務(wù)處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
SpringBoot讀取resource目錄下文件失敗的原因及解決方案
在idea中運(yùn)行時(shí),有些resource下文件讀取工具類能夠正常獲取讀取到文件,但是通過java–jar的方式去運(yùn)行jar包,此時(shí)resource下文件讀取工具類讀取文件就失效了,本文就給大家介紹一下SpringBoot讀取resource目錄下文件失敗解決方案,需要的朋友可以參考下2023-08-08
java多線程并發(fā)中使用Lockers類將多線程共享資源鎖定
Lockers在多線程編程里面一個(gè)重要的概念是鎖定,如果一個(gè)資源是多個(gè)線程共享的,為了保證數(shù)據(jù)的完整性,在進(jìn)行事務(wù)性操作時(shí)需要將共享資源鎖定,這樣可以保證在做事務(wù)性操作時(shí)只有一個(gè)線程能對(duì)資源進(jìn)行操作,下面看一個(gè)示例2014-01-01
SpringCloud?Eureka應(yīng)用全面介紹
Eureka是Netflix開發(fā)的服務(wù)發(fā)現(xiàn)框架,本身是一個(gè)基于REST的服務(wù),主要用于定位運(yùn)行在AWS域中的中間層服務(wù),以達(dá)到負(fù)載均衡和中間層服務(wù)故障轉(zhuǎn)移的目的2022-09-09

