SpringBoot系列(20):SpringBoot项目启动成功后初始化执行一些骚操作

作者: 修罗debug
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。


摘要:在开发企业级应用系统的过程中,难免需要设定项目在启动过程中或者项目启动成功后初始化一些资源,甚至执行一些骚操作,比如初始化第三方应用服务的账号密码、将系统字典数据初始化至缓存中等操作。本文我们将介绍如何基于CommandLineRunner,实现项目在启动成功之后执行一些骚操作、初始化一些资源的功能!

内容:“在项目的启动过程中或者项目启动成功后初始化一些资源、或者执行一些骚操作”,有些小伙伴听到这么一句需求,可能第一时间会想到“@PostConstruct”注解,确实,这个注解可以实现项目在启动过程中执行一些操作或者初始化一些资源,但是请记住,这个注解所注解的方法的业务逻辑是在“项目的启动过程中”阶段执行的,而不是“项目启动成功后”阶段。

如下代码所示为“@PostConstruct”注解所注解的方法,其方法内容逻辑也不复杂,就只打印一句话:

/**
* @Author:debug (SteadyJack)
* @Link: weixin-> debug0868 qq-> 1948831260
* @Date: 2019/11/14 17:06
**/
@Service
public class InitRunnerService {
private static final Logger log= LoggerFactory.getLogger(InitRunnerService.class);

@PostConstruct
public void init(){
log.info("--@PostConstruct方式-SpringBoot容器启动之后执行一些初始化的内容....--");

}
}

点击运行项目,观察项目的运行情况,会发现,“@PostConstruct”注解所注解的方法的逻辑在项目的启动过程的某个阶段成功执行了,如下所示:


然而,这并非是我们所想要的,我们想要的在“项目启动成功后”的阶段执行一些我们制定的方法逻辑或者初始化一些资源,而不是在项目的启动过程!

之所以不是在“项目的启动过程”阶段执行,是因为万一该注解所注解的方法的业务逻辑执行起来时间很长或者在执行的过程出现了一些令人意想不到的异常,那么很有可能会因此而影响整个项目的启动过程,甚至会出现“项目启动失败”的现象!

因此,才有了本文的需求重点“在项目完全启动成功后执行一些骚操作或者初始化一些资源”!在讲解怎么实现之前,Debug给大家绘制了一幅“SpringBoot项目在启动的过程中大致需要做的一些表象上的事情的流程图”,如下所示:


“@PostConstruct”注解所注解的方法的逻辑的执行时机便是穿插在整个启动流程的某个阶段执行!

下面我们介绍如何基于“CommandLineRunner”接口实现项目在启动成功之后执行一些骚操作、初始化一些资源的功能!如果需要在项目启动成功之后做许多初始化操作,那么可以分成多个“实现CommandLineRunner接口”的实现类去执行,同时采用@Order(num)注解标注该实现类,num数值越小,就越先执行,其代码如下所示:

第一个:

/**
* spring boot项目启动之后执行一些初始化的内容1
* @Author:debug (SteadyJack)
* @Link: weixin-> debug0868 qq-> 1948831260
* @Date: 2019/11/14 16:49
**/
@Component
@Order(1)
public class InitRunnerOne implements CommandLineRunner{

private static final Logger log= LoggerFactory.getLogger(InitRunnerOne.class);

@Autowired
private SysConfigMapper sysConfigMapper;

//TODO:SpringBoot容器启动之后执行一些初始化的内容:比如将一些频繁访问的数据字典塞至缓存中....
@Override
public void run(String... strings) throws Exception {
log.info("--1~SpringBoot容器启动之后执行一些初始化的内容....--");

SysConfig sysConfig=sysConfigMapper.selectByPrimaryKey(5);
log.info("--项目启动成功后初始化资源:{}",sysConfig);
}
}

第二个:  

@Component
@Order(2)
public class InitRunnerTwo implements CommandLineRunner{

private static final Logger log= LoggerFactory.getLogger(InitRunnerTwo.class);

//TODO:SpringBoot容器启动之后执行一些初始化的内容....
@Override
public void run(String... strings) throws Exception {
log.info("--2~SpringBoot容器启动之后执行一些初始化的内容....--");

}
}

废话不多说,直接将项目启动起来,观察控制台的输出,会发现最终的输出结果如我们所愿!


好了,本篇文章我们就介绍到这里了,其他相关的技术,感兴趣的小伙伴可以关注底部Debug的技术公众号,或者加Debug的微信,拉你进“微信版”的真正技术交流群!一起学习、共同成长!

补充:

1、本文涉及到的相关的源代码可以到此地址,check出来进行查看学习:

https://gitee.com/steadyjack/SpringBootTechnology

2、最近Debug发布了几门重量级的课程,感兴趣的小伙伴可以前往观看学习:
(1) 缓存中间件Redis技术入门与应用场景实战(SpringBoot2.x + 抢红包系统设计与实战) 
https://www.fightjava.com/web/index/course/detail/12

(2)  企业权限管理平台(SpringBoot2.0+Shiro+Vue+Mybatis) 
https://www.fightjava.com/web/index/course/detail/8

3、关注一下Debug的技术微信公众号,最新的技术文章、课程以及技术专栏将会第一时间在公众号发布哦!