欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringBoot 在项目启动之后执行自定义方法的两种方式小结

程序员文章站 2022-06-24 19:35:01
目录springboot 项目启动之后执行自定义方法的两种方式方式一 实现 commandlinerunner 接口方式二 实现 applicationrunner 接口springboot 项目启动...

springboot 项目启动之后执行自定义方法的两种方式

在测试配置中心的配置时,想在项目启动成功之后打印配置项,然后需要执行自定义的类

一般项目中也会在这个地方进行初始化数据的一些操作

方式一 实现 commandlinerunner 接口

自定义类并实现 commandlinerunner 接口,实现run()方法,需要执行的语句就放在 run() 方法中

例:

@component
@order(1)  // 控制类执行的顺序越小越靠前
public class startinitializer implements commandlinerunner {
    @override
    public void run(string... args) throws exception {
        system.out.println("项目启动,执行 commandlinerunner 实现类的方法");
    }
}

方式二 实现 applicationrunner 接口

自定义类并实现 applicationrunner 接口,实现run()方法,需要执行的语句就放在 run() 方法中

例:

@component
@order(2) // 控制类执行的顺序越小越靠前
public class appinitializer implements applicationrunner {
    @override
    public void run(applicationarguments args) throws exception {
        system.out.println("项目启动,执行 applicationrunner 实现类的方法");
    }
}

二者区别

区别在于实现方法 run() 中的参数类型不一样

实现 applicationrunner 接口的 run() 方法参数类型为: applicationarguments

实现 commandlinerunner 接口的 run() 方法参数类型为: string...

实现效果

SpringBoot 在项目启动之后执行自定义方法的两种方式小结

springboot 项目启动后执行某些自定义代码

springboot给我们提供了两种“开机启动”某些方法的方式:applicationrunner和commandlinerunner。

这两种方法提供的目的是为了满足,在项目启动的时候立刻执行某些方法。我们可以通过实现applicationrunner和commandlinerunner,来实现,他们都是在springapplication 执行之后开始执行的。

commandlinerunner接口可以用来接收字符串数组的命令行参数,applicationrunner 是使用applicationarguments 用来接收参数的

代码示例

@component//被spring容器管理
@order(1)//如果多个自定义applicationrunner,用来标明执行顺序
public class myapplicationrunner implements applicationrunner {
    @override
    public void run(applicationarguments applicationarguments) throws exception {
        system.out.println("-------------->" + "项目启动,now=" + new date());
        mytimer();
    }
    public static void mytimer(){
        timer timer = new timer();
        timer.schedule(new timertask() {
            @override
            public void run() {
                system.out.println("------定时任务--------");
            }
        }, 0, 1000);
    }
}

执行结果

2018-02-08 14:10:16.490  info 10236 --- [           main] s.b.c.e.t.tomcatembeddedservletcontainer : tomcat started on port(s): 8081 (http)
-------------->项目启动,now=thu feb 08 14:10:16 cst 2018
------定时任务--------
2018-02-08 14:10:16.497  info 10236 --- [           main] com.mlxs.springboot01.web.mainapp        : started mainapp in 5.595 seconds (jvm running for 6.334)
------定时任务--------
------定时任务--------
------定时任务--------
------定时任务--------
------定时任务--------
------定时任务--------

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。