SpringBoot中的ApplicationRunner與CommandLineRunner問題
概述
開發(fā)中可能會有這樣的場景,需要在容器啟動的時候執(zhí)行一些內(nèi)容。比如讀取配置文件,數(shù)據(jù)庫連接之類的。
SpringBoot給我們提供了兩個接口來幫助我們實現(xiàn)這種需求。
兩個啟動加載接口分別是:
CommandLineRunner
ApplicationRunner
他們的執(zhí)行時機是容器啟動完成的時候。
實現(xiàn)啟動加載接口
這兩個接口中有一個run方法,我們只需要實現(xiàn)這個方法即可。這個兩個接口的不同之處在于:
ApplicationRunner中的run方法的參數(shù)為ApplicationArguments,而CommandLineRunner接口中run方法的參數(shù)為String數(shù)組。
ApplicationRunner接口的示例
package com.jdddemo.demo.controller; import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationRunner; import org.springframework.stereotype.Component; @Component @Order(value = 1) public class JDDRunner implements ApplicationRunner { @Override public void run(ApplicationArguments args) throws Exception { System.out.println(args); System.out.println("這個是測試ApplicationRunner接口"); } }
執(zhí)行結果如下:
CommandLineRunner接口示例
import org.springframework.boot.CommandLineRunner; import org.springframework.stereotype.Component; @Component public class TestCommandLineRunner implements CommandLineRunner { @Override public void run(String... args) throws Exception { System.out.println("<這個是測試CommandLineRunn接口"); } }
CommandLineRunner和ApplicationRunner的執(zhí)行順序
在spring boot程序中,我們可以使用不止一個實現(xiàn)CommandLineRunner和ApplicationRunner的bean。
為了有序執(zhí)行這些bean的run()方法,可以使用@Order注解或Ordered接口。
下面例子中創(chuàng)建了兩個實現(xiàn)CommandLineRunner接口bean和兩個實現(xiàn)ApplicationRunner接口的bean。
我們使用@Order注解按順序執(zhí)行這四個bean
CommandLineRunnerBean1.java
@Component @Order(1) public class CommandLineRunnerBean1 implements CommandLineRunner { ? ? @Override ? ? public void run(String... args) { ? ? ? ? System.out.println("CommandLineRunnerBean 1"); ? ? } }
ApplicationRunnerBean1.java
@Component @Order(2) public class ApplicationRunnerBean1 implements ApplicationRunner { ? ? @Override ? ? public void run(ApplicationArguments arg0) throws Exception { ? ? ? ? System.out.println("ApplicationRunnerBean 1"); ? ? } }
CommandLineRunnerBean2.java
@Component @Order(3) public class CommandLineRunnerBean2 implements CommandLineRunner { ? ? @Override ? ? public void run(String... args) { ? ? ? ? System.out.println("CommandLineRunnerBean 2"); ? ? } }
ApplicationRunnerBean2.java
@Component @Order(4) public class ApplicationRunnerBean2 implements ApplicationRunner { ? ? @Override ? ? public void run(ApplicationArguments arg0) throws Exception { ? ? ? ? System.out.println("ApplicationRunnerBean 2"); ? ? } }
輸出結果為:
CommandLineRunnerBean 1
ApplicationRunnerBean 1
CommandLineRunnerBean 2
ApplicationRunnerBean 2
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Spring?Mvc中CommonsMultipartFile的特性實例詳解
這篇文章主要給大家介紹了關于Spring?Mvc中CommonsMultipartFile特性的相關資料,SpringMVC擁有強大的靈活性,非侵入性和可配置性,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-11-11SpringBoot結合JWT實現(xiàn)用戶登錄、注冊、鑒權
用戶登錄、注冊及鑒權是我們基本所有系統(tǒng)必備的,也是很核心重要的一塊,本文主要介紹了SpringBoot結合JWT實現(xiàn)用戶登錄、注冊、鑒權,具有一定的參考價值,感興趣的小伙伴們可以參考一下2023-05-05MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報錯問題
這篇文章主要介紹了MyBatisPuls多數(shù)據(jù)源操作數(shù)據(jù)源偶爾報錯問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06Spring內(nèi)存緩存Caffeine的基本使用教程分享
Caffeine作為當下本地緩存的王者被大量的應用再實際的項目中,可以有效的提高服務吞吐率、qps,降低rt,本文就來簡單介紹下Caffeine的使用姿勢吧2023-03-03