SpringBootRunner简单实践

2020-06-22 10:42:22 浏览数 (2)

本文演示了SpringBoot基于CommandLineRunner及ApplicationRunner的启动参数读取模式

CommandLineRunner

CommandLineRunner与ApplicationRunner的区别只是run方法的参数差异,这两个runner都主要用户类似开机启动的场景,也就是在服务启动完成,所有bean初始化完毕后,回调runner接口的run方法,完成资源初始化等操作,例如redis中缓存初始化等。

下面是个cmdrunner示例:

代码语言:txt复制
@Component
@Order(1)
@Slf4j
public class CmdRunner implements CommandLineRunner {
    @Override
    public void run(String... args) throws Exception {
        log.info("在全部bean初始化完成后调用");
        log.info("可通过CommandLineRunner实现类来进行资源初始化等操作");
        //打印 program args
        for (String arg : args) {
            log.info(arg);
        }
        // 打印vm options
        log.info(System.getProperty("vmarg"));
    }
}

ApplicationRunner

applicationrunner可以更结构化的读取参数,而不需要自行基于string值进行解析:

代码语言:txt复制
@Component
@Order(2)
@Slf4j
public class AppRunner implements ApplicationRunner {
    @Override
    public void run(ApplicationArguments args) throws Exception {
        log.info("基于Order第二优先级启动");
        log.info("与CommandLineRunner区别是获取参数的方式不一样,也就是run方法的参数不一样");
        //获取并打印option args,例如 --parg=p1
        args.getOptionNames().forEach(name -> {
            log.info("{}:{}", name, args.getOptionValues(name));
        });
        log.info("NonOptionArgs:{}", args.getNonOptionArgs());
    }
}

同时,有多个runner时,可通过@Order注解来制定启动顺序。

启动参数运行验证

如果功能idea,可以在 edit configurations中,分别配置vm optinos 和 program arguments,具体如下:

代码语言:txt复制
vm options:-Dvmarg=v1
program arguments:--parg=p1 --parg=p2 p3

同样,也可以在命令行执行并传递启动参数,具体如下:

代码语言:txt复制
java -jar hiboot-1.0-SNAPSHOT.jar -Dvmarg=v1 --parg=p1 --parg=p2 p3

运行后,控制台输入内容如下

代码语言:txt复制
Started RunnerApplication in 1.432 seconds (JVM running for 2.097)
在全部bean初始化完成后调用
可通过CommandLineRunner实现类来进行资源初始化等操作
--parg=p1
--parg=p2
p3
v1
基于Order第二优先级启动
与CommandLineRunner区别是获取参数的方式不一样,也就是run方法的参数不一样
parg:[p1, p2]
NonOptionArgs:[p3]
SourceArgs:--parg=p1

0 人点赞