SpringBoot(二十一)ApplicationRunner和CommandLineRunner实现开机自启

目录

ApplicationRunner

CommandLineRunner

总结


SpringBoot版本:2.1.1

SpringBoot应用启动成功以后就会callRunners方法,方法中调用ApplicationRunner和CommandLineRunner接口的run方法,只在启动成功以后调用一次。所以,在这基础上就可以实现相当于开机自启的一个操作,具体执行的逻辑代码就看在应用启动后需要做什么事情了,比如初始化一些数据,下面是run方法源码。

ApplicationRunner

实现ApplicationRunner接口,重写run方法,方法参数是ApplicationArguments,解析封装过后的args参数,具体解析过程移步这里命令行参数args的封装解析。通过该对象既可以拿到原始命令行参数,也可以拿到解析后的参数,对应方法写在下面的代码里了。其中@Order中的值指定了执行顺序,值小的先执行。默认值是Integer.MAX_VALUE;这里只做演示,具体执行的业务逻辑嘛,具体问题具体分析。

import java.util.Arrays;
import java.util.Set;

import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

@Component
@Order(1)
public class MyApplicationRunner implements ApplicationRunner {

	@Override
	public void run(ApplicationArguments args) throws Exception {
		System.out.println("====================MyApplicationRunner================");
		System.out.println("order值: 1");
		System.out.println("原始参数:"+Arrays.asList(args.getSourceArgs()));
		Set<String> keys = args.getOptionNames();
		for (String key : keys) {
			System.out.println("解析后的key: ["+key+"]  value: "+args.getOptionValues(key));
		}
		System.out.println("无OptionName的参数: "+args.getNonOptionArgs());
		System.out.println("=======================================================");
	}
}

 启动项目,在SpringApplication.run()方法执行的最后,就会callRunners,启动流程分析移步这SpringBoot启动流程分析

至于参数,如下,后面两个参数只是为了测试随便加的,无意义,除了在编码工具里添加命令行参数,也可以在项目打包以后,启动的时候在java -jar后面直接加,是一样的。

 控制台输出,参数解析过程就不叙述了,将cmd和eclipse里的输出贴下面了。

CommandLineRunner

同样的实现CommandLineRunner接口,重写run方法,方法参数是原始args参数。上面MyApplicationRunner的order值指定是1,这里MyCommandLineRunner的order值指定为2,那么前者会先执行。

import java.util.Arrays;

import org.springframework.boot.CommandLineRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

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

	@Override
	public void run(String... args) throws Exception {
		// TODO Auto-generated method stub
		System.out.println("====================MyCommandLineRunner================");
		System.out.println("order值: 2");
		System.out.println("原始参数: "+Arrays.asList(args));
		System.out.println("=======================================================");
	}
}

执行结果

总结

两种方法用法可以说是一样的,区别只在于方法的参数,一个是经过解析后的,一个是原始的命令行参数,具体用哪个,可看实际情况定夺。

  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值