Spring Boot啟動(dòng)及退出加載項(xiàng)的方法
在一個(gè)初春的下午,甲跟我說(shuō),要在Spring Boot啟動(dòng)服務(wù)的時(shí)候,設(shè)置表自增的起始值。
于是我用屁股想了一下,不就是在main方法里折騰嘛。
后來(lái)實(shí)際操作了一把,發(fā)現(xiàn)屁股被打了。
于是乎,找到官方文檔(以2.1.4為例),找到這一段:

如果你需要在啟動(dòng)SpringApplication后執(zhí)行一些具體的代碼,你可以實(shí)現(xiàn)ApplicaitonRunner或者CommandLineRunner接口。兩個(gè)接口都實(shí)現(xiàn)了一個(gè)工作方式相同的run方法,該方法僅會(huì)在SpringApplication.run(...)前執(zhí)行。
唯一不同的是實(shí)現(xiàn)CommandLineRunner接口的run方法參數(shù)為String類型,而實(shí)現(xiàn)ApplicaitonRunner的run方法的參數(shù)則是需要ApplicationArguments。官方文檔中有個(gè)例子供參考。
如果有多個(gè)ApplicaitonRunner或者CommandLineRunner接口的實(shí)現(xiàn)存在啟動(dòng)順序,則可以使用org.springframework.core.Ordered接口或者org.springframework.core.annotation.Order注解的形式來(lái)給他們排序。
由于我沒(méi)有參數(shù)類型等的限制,所以用哪個(gè)接口都一樣,寫個(gè)跟官方不一樣的,于是代碼大概長(zhǎng)這樣:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
@Component
public class InstructionStart implements ApplicationRunner {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@Autowired
private JdbcTemplate template;
@Override
public void run(ApplicationArguments applicationArguments) throws Exception {
String increment = "0";
logger.info("初始化遞增起始值為:{}", increment);
template.execute("ALTER TABLE `table` AUTO_INCREMENT = " + increment);
}
}
深刻的意識(shí)到腦子和屁股一樣重要。
寫完啟動(dòng)項(xiàng),那么再把退出也說(shuō)一下:

每一個(gè)SpringApplication都應(yīng)該向JVM注冊(cè)一個(gè)鉤子函數(shù)來(lái)確保ApplicationContext能優(yōu)雅地關(guān)閉。使所有的標(biāo)準(zhǔn)Spring生命周期回調(diào)(例如DisposableBean接口和@PreDestroy注解)都可用。
此外,如果你希望beans在調(diào)用SpringApplication.exit()時(shí)返回特定的退出代碼,則可以實(shí)現(xiàn)org.springframework.boot.ExitCodeGenerator接口,這些退出代碼會(huì)被傳給System.exit()作為返回的狀態(tài)碼。官方還給了個(gè)例子,就是下面這個(gè)。
@SpringBootApplication
public class ExitCodeApplication {
@Bean
public ExitCodeGenerator exitCodeGenerator() {
return () -> 42;
}
public static void main(String[] args) {
System.exit(SpringApplication
.exit(SpringApplication.run(ExitCodeApplication.class, args)));
}
}
當(dāng)然,ExitCodeGenerator也可以由異常來(lái)實(shí)現(xiàn),當(dāng)遇到一個(gè)這樣的異常時(shí),Sprin Boot會(huì)返回實(shí)現(xiàn)了getExitCode()方法的退出代碼。
后面退出部分翻譯地磕磕碰碰的,有不對(duì)的地方歡迎指正。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
idea中maven項(xiàng)目模塊變成灰色原因及解決方案
這篇文章主要介紹了idea中maven項(xiàng)目模塊變成灰色原因及解決方案,文中通過(guò)圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03
Struts2中圖片以base64方式上傳至數(shù)據(jù)庫(kù)
這篇文章主要介紹了Struts2中圖片以base64方式上傳至數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼,代碼分為前臺(tái)和后臺(tái)兩段,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
java web服務(wù)器實(shí)現(xiàn)跨域訪問(wèn)
這篇文章主要為大家詳細(xì)介紹了java web服務(wù)器實(shí)現(xiàn)跨域訪問(wèn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
Java中CountDownLatch工具類詳細(xì)解析
這篇文章主要介紹了Java中CountDownLatch工具類詳細(xì)解析,創(chuàng)建CountDownLatch對(duì)象時(shí),會(huì)傳入一個(gè)count數(shù)值,該對(duì)象每次調(diào)用countDown()方法會(huì)使count?--?,就是count每次減1,需要的朋友可以參考下2023-11-11
使用Spring Boot Maven插件的詳細(xì)方法
這篇文章主要介紹了如何使用Spring Boot Maven插件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Java 入門圖形用戶界面設(shè)計(jì)之復(fù)選框
圖形界面(簡(jiǎn)稱GUI)是指采用圖形方式顯示的計(jì)算機(jī)操作用戶界面。與早期計(jì)算機(jī)使用的命令行界面相比,圖形界面對(duì)于用戶來(lái)說(shuō)在視覺(jué)上更易于接受,本篇精講Java語(yǔ)言中關(guān)于圖形用戶界面的復(fù)選框2022-02-02
Spring Boot中使用Redis和Lua腳本實(shí)現(xiàn)延時(shí)隊(duì)列的方案
通過(guò)使用Redis和Lua腳本,可以在Spring Boot環(huán)境中實(shí)現(xiàn)一個(gè)高效且可靠的延時(shí)隊(duì)列系統(tǒng),這種方法利用了Redis的有序集合數(shù)據(jù)結(jié)構(gòu)和Lua腳本的原子性操作來(lái)確保任務(wù)的正確性和一致性,這篇文章主要介紹了Spring Boot中使用Redis和Lua腳本實(shí)現(xiàn)延時(shí)隊(duì)列,需要的朋友可以參考下2024-05-05
Java計(jì)算器核心算法代碼實(shí)現(xiàn)
今天小編就為大家分享一篇關(guān)于Java計(jì)算器核心算法代碼實(shí)現(xiàn),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01

