SpringBoot項(xiàng)目執(zhí)行腳本 自動(dòng)拉取最新代碼并重啟的實(shí)例內(nèi)容
gitPullThenRestart.sh
# 日期: 20191230
# 作者: 何鵬舉
# 說明: 項(xiàng)目部署在阿里云上, 每次編譯打包上傳比較麻煩, 因此編寫此腳本, 用于應(yīng)用內(nèi)可以點(diǎn)擊按鈕進(jìn)行自動(dòng)重啟.
# 備注: 1) 阿里云的插件也是需要每次上傳到OSS再啟動(dòng), 上傳的jar包比較大(大部分是第三方依賴), 感覺不好
# 2) 使用jenkins, 就一個(gè)項(xiàng)目再去搭建一套jenkins, 必要性也不是很大
# 以下代碼中 /root/hekele 為git clone的項(xiàng)目路徑, /root/app 為部署的路徑
# 刷新環(huán)境變量
source ~/.bashrc
# 切換到git項(xiàng)目目錄拉取最新代碼, 并進(jìn)行mvn的打包
cd /root/hekele
git pull
cd /root/hekele/java
mvn clean install
# 殺掉當(dāng)前項(xiàng)目的進(jìn)程
ps -ef|grep hekele.jar | awk '{print $2}' | while read pid
do
kill -9 $pid
done
# 復(fù)制jar包, 強(qiáng)制覆蓋(忽略提醒), 由于CentOS的.bashrc中打開cp的-i選項(xiàng), 即可使用-f也不行, 所以還是先刪除再復(fù)制
rm -f /root/app/hekele.jar
cp /root/hekele/java/target/hekele.jar /root/app/
# 后臺(tái)啟動(dòng)項(xiàng)目
nohup java -jar /root/app/hekele.jar >> /root/app/hekele.log 2>&1 &
# 查看日志(備注: kill掉之后, 其復(fù)制jar包和啟動(dòng)還是執(zhí)行了, 原因暫時(shí)未知... 此句話在手動(dòng)啟動(dòng)可用, 自動(dòng)重啟實(shí)測也沒影響)
tail -f /root/app/hekele.log
JavaController
@ApiOperation("拉取最新代碼然后重啟應(yīng)用")
@GetMapping("gitPullThenRestart")
public R gitPullThenRestart() {
// 必須開啟一個(gè)新線程, 從而返回給瀏覽器, 否則瀏覽器得不到響應(yīng), 還會(huì)再次發(fā)送
new Thread(() -> ExecUtil.execCommand(restartShell)).start();
return R.ok().setErrmsg("正在重新啟動(dòng), 請稍等");
}
JavaExecUtil
/**
* 執(zhí)行系統(tǒng)命令
*
*
* <br> 注意死鎖問題
* <br> 解決: 只要主進(jìn)程在waitfor之前,能不斷處理緩沖區(qū)中的數(shù)據(jù)就可以
*
* @see <a rel="external nofollow" >調(diào)用Process.waitfor導(dǎo)致的進(jìn)程掛起</a>
*
* @author he_pe
*
*/
@Slf4j
public class ExecUtil {
public static void execCommand(String command) {
log.info("begin exec os command: " + command);
Process process;
try {
process = Runtime.getRuntime().exec(command);
//開啟新線程處理正常輸出 和 錯(cuò)誤輸出
newThreadLogInputStream(process.getInputStream());
newThreadLogInputStream(process.getErrorStream());
// 阻塞當(dāng)前進(jìn)程,直到命令結(jié)束
process.waitFor();
// 不會(huì)阻塞進(jìn)程,但是調(diào)用時(shí)如果沒有完成會(huì)報(bào)錯(cuò)
if (process.exitValue() != 0) {
log.error("exec os command failure: " + command);
} else {
log.info("exec os command success: " + command);
}
} catch (Exception e) {
log.error(e.getMessage(), e);
}
}
private static void newThreadLogInputStream(InputStream is){
new Thread(() -> {
try(InputStream inputStream = is;
BufferedReader bufr = new BufferedReader(new InputStreamReader(inputStream))){
String out = null;
while ((out = bufr.readLine()) != null) {
log.info(out);
}
} catch (IOException e) {
}
}).start();
}
}
以上就是本知識(shí)點(diǎn)的全部代碼內(nèi)容,感謝大家的學(xué)習(xí)和對腳本之家的支持。
- SpringBoot啟動(dòng)時(shí)自動(dòng)執(zhí)行代碼的幾種實(shí)現(xiàn)方式
- springboot 項(xiàng)目容器啟動(dòng)后如何自動(dòng)執(zhí)行指定方法
- SpringBoot啟動(dòng)時(shí)自動(dòng)執(zhí)行sql腳本的方法步驟
- Spring Boot 項(xiàng)目啟動(dòng)自動(dòng)執(zhí)行方法的兩種實(shí)現(xiàn)方式
- springBoot啟動(dòng)時(shí)讓方法自動(dòng)執(zhí)行的幾種實(shí)現(xiàn)方式
- Spring Boot應(yīng)用啟動(dòng)時(shí)自動(dòng)執(zhí)行代碼的五種方式(常見方法)
相關(guān)文章
mybatis學(xué)習(xí)之路mysql批量新增數(shù)據(jù)的方法
這篇文章主要介紹了mybatis學(xué)習(xí)之路mysql批量新增數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
詳解Spring依賴注入的三種方式使用及優(yōu)缺點(diǎn)
這篇文章主要介紹了spring依賴注入的三種方式的使用方法,以及優(yōu)缺點(diǎn)的介紹,通過代碼示例介紹的非常詳細(xì),感興趣的小伙伴可以參考一下2023-04-04
Spring data jpa @Query update的坑及解決
這篇文章主要介紹了Spring data jpa @Query update的坑及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
淺析springboot通過面向接口編程對控制反轉(zhuǎn)IOC的理解
這篇文章主要介紹了springboot通過面向接口編程對控制反轉(zhuǎn)IOC的理解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-08-08
SpringBoot超詳細(xì)講解Thymeleaf模板引擎
這篇文章主要分享了Spring Boot整合使用Thymeleaf,Thymeleaf是新一代的Java模板引擎,類似于Velocity、FreeMarker等傳統(tǒng)引擎,關(guān)于其更多相關(guān)內(nèi)容,需要的小伙伴可以參考一下2022-07-07
springboot項(xiàng)目接入第三方qq郵箱驗(yàn)證登錄的全過程
互聯(lián)網(wǎng)發(fā)展到現(xiàn)在,相必大家都知道發(fā)送郵件應(yīng)該是網(wǎng)站的必備功能之一,下面這篇文章主要給大家介紹了關(guān)于springboot項(xiàng)目接入第三方qq郵箱驗(yàn)證登錄的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
Dubbo+zookeeper搭配分布式服務(wù)的過程詳解
Dubbo作為分布式架構(gòu)比較后的框架,同時(shí)也是比較容易入手的框架,適合作為分布式的入手框架,下面是簡單的搭建過程,對Dubbo+zookeeper分布式服務(wù)搭建過程感興趣的朋友一起看看吧2022-04-04

