摘要:在一個(gè)初春的下午,甲跟我說(shuō),要在啟動(dòng)服務(wù)的時(shí)候,設(shè)置表自增的起始值。寫(xiě)完啟動(dòng)項(xiàng),那么再把退出也說(shuō)一下每一個(gè)都應(yīng)該向注冊(cè)一個(gè)鉤子函數(shù)來(lái)確保能優(yōu)雅地關(guān)閉。后面退出部分翻譯地磕磕碰碰的,有不對(duì)的地方歡迎指正。原創(chuà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è)接口都一樣,寫(xiě)個(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í)到腦子和屁股一樣重要。
寫(xiě)完啟動(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ì)的地方歡迎指正。
原創(chuàng)不易,感謝支持。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/77478.html
摘要:開(kāi)發(fā)你的第一個(gè)應(yīng)用程序本節(jié)描述如何開(kāi)發(fā)一個(gè)簡(jiǎn)單的應(yīng)用程序來(lái)突出了的一些關(guān)鍵特性,我們使用來(lái)構(gòu)建這個(gè)項(xiàng)目,因?yàn)榇蠖鄶?shù)都支持它。如果你希望分發(fā)一個(gè)自包含的應(yīng)用程序,這可能會(huì)有問(wèn)題。 11. 開(kāi)發(fā)你的第一個(gè)Spring Boot應(yīng)用程序 本節(jié)描述如何開(kāi)發(fā)一個(gè)簡(jiǎn)單的Hello World! web應(yīng)用程序來(lái)突出了Spring Boot的一些關(guān)鍵特性,我們使用Maven來(lái)構(gòu)建這個(gè)項(xiàng)目,因?yàn)榇蠖鄶?shù)...
摘要:結(jié)束語(yǔ)非常智能化,為開(kāi)發(fā)者提供大量的默認(rèn)配置細(xì)節(jié),因此在的幫助下可以快速完成項(xiàng)目的運(yùn)行,極簡(jiǎn)入門(mén)繼續(xù)看從零入門(mén)系列程序結(jié)構(gòu)設(shè)計(jì)說(shuō)明 環(huán)境準(zhǔn)備 java 開(kāi)發(fā)環(huán)境 JDK1.8 安裝 Maven 安裝,jar自動(dòng)依賴及包管理工具 IDE編輯器:IntelliJ IDEA 2019 說(shuō)明 本項(xiàng)目為從零入門(mén)示例,目標(biāo)為構(gòu)建一個(gè)書(shū)籍增刪改查管理頁(yè),力爭(zhēng)記錄一個(gè)無(wú)java基礎(chǔ)的程序員學(xué)習(xí)筆...
摘要:觸發(fā)器文件可以手動(dòng)更新,也可以使用插件進(jìn)行更新。例如,要配置重新啟動(dòng)以始終使用觸發(fā)器文件,你需要添加以下屬性遠(yuǎn)程應(yīng)用程序開(kāi)發(fā)工具并不局限于本地開(kāi)發(fā),在遠(yuǎn)程運(yùn)行應(yīng)用程序時(shí),還可以使用幾個(gè)特性。 20. 開(kāi)發(fā)者工具 Spring Boot包括一組額外的工具,這些工具可以使應(yīng)用程序開(kāi)發(fā)體驗(yàn)變得更加愉快,spring-boot-devtools模塊可以包含在任何項(xiàng)目中,以提供額外的develo...
閱讀 3055·2023-04-26 03:01
閱讀 3546·2023-04-25 19:54
閱讀 1598·2021-11-24 09:39
閱讀 1381·2021-11-19 09:40
閱讀 4260·2021-10-14 09:43
閱讀 2077·2019-08-30 15:56
閱讀 1501·2019-08-30 13:52
閱讀 1668·2019-08-29 13:05