在一个初春的下午,甲跟我说,要在Spring Boot启动服务的时候,设置表自增的起始值。
于是我用屁股想了一下,不就是在main方法里折腾嘛。
后来实际操作了一把,发现屁股被打了。
于是乎,找到官方文档(以2.1.4为例),找到这一段:
如果你需要在启动SpringApplication后执行一些具体的代码,你可以实现ApplicaitonRunner
或者CommandLineRunner
接口。两个接口都实现了一个工作方式相同的run
方法,该方法仅会在SpringApplication.run(...)前执行。
唯一不同的是实现CommandLineRunner
接口的run
方法参数为String
类型,而实现ApplicaitonRunner
的run
方法的参数则是需要ApplicationArguments
。官方文档中有个例子供参考。
如果有多个ApplicaitonRunner
或者CommandLineRunner
接口的实现存在启动顺序,则可以使用org.springframework.core.Ordered
接口或者org.springframework.core.annotation.Order
注解的形式来给他们排序。
由于我没有参数类型等的限制,所以用哪个接口都一样,写个跟官方不一样的,于是代码大概长这样:
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); } }
深刻的意识到脑子和屁股一样重要。
写完启动项,那么再把退出也说一下:
每一个SpringApplication
都应该向JVM
注册一个钩子函数来确保ApplicationContext
能优雅地关闭。使所有的标准Spring
生命周期回调(例如DisposableBean
接口和@PreDestroy
注解)都可用。
此外,如果你希望beans在调用SpringApplication.exit()
时返回特定的退出代码,则可以实现org.springframework.boot.ExitCodeGenerator
接口,这些退出代码会被传给System.exit()
作为返回的状态码。官方还给了个例子,就是下面这个。
@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))); } }
当然,ExitCodeGenerator
也可以由异常来实现,当遇到一个这样的异常时,Sprin Boot会返回实现了getExitCode()
方法的退出代码。
后面退出部分翻译地磕磕碰碰的,有不对的地方欢迎指正。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。