CommandLineRunner的使用

背景

在项目启动时需要做一些数据预加载或者某些操作,需要怎么办呢,方法其实有好几种,这里主要讲一下SpringBoot提供的CommandLineRunner接口的使用。

一、案例说明以及实现

1.实现CommandLineRunner接口

定义一个类实现CommandLineRunner接口,模拟启动项目时的预加载处理。

package com.lbl.run;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class WebStart implements CommandLineRunner {

    @Override
    public void run(String... args) throws Exception {
        log.info("------------- WebStart ---------------");
    }
}
  • 启动类
package com.lbl;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@Slf4j
@SpringBootApplication
public class SpringbootDemoApplication {

    public static void main(String[] args) {
        log.info("------------- before ---------------");
        SpringApplication.run(SpringbootDemoApplication.class, args);
        log.info("------------- after ---------------");
    }

}
  • 启动启动类,查看日志的打印
    在这里插入图片描述

2.加载的顺序

  • 如果有多个实现类,我们可以使用@Order()注解控制它们的加载顺序,数字越小加载越早。现在创建多一个CommandLineRunnerd的实现类,给它们加上@Order()注解。
package com.lbl.run;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.CommandLineRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

@Slf4j
@Component
@Order(2)
public class WebStart implements CommandLineRunner {

    @Override
    public void run(String... args) throws Exception {
        log.info("------------- WebStart ---------------");
    }
}
package com.lbl.run;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.CommandLineRunner;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

@Slf4j
@Component
@Order(1)
public class WebStart2 implements CommandLineRunner {
    @Override
    public void run(String... args) throws Exception {
        log.info("------------- WebStart2 ---------------");
    }
}

  • 启动启动类,查看日志的打印
    在这里插入图片描述

3.扩展-ApplicationRunner

  • 除了实现CommandLineRunner接口可以完成项目启动时的预加载动作,还有ApplicationRunner也能实现同样的功能,并且在不设置@Order()的情况下,ApplicationRunner的优先级大于CommandLineRunner。
package com.lbl.run;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class WebStart3 implements ApplicationRunner {

    @Override
    public void run(ApplicationArguments args) throws Exception {
        log.info("------------- WebStart3 ---------------");
    }
}

此时注掉前面两个实现类的@Order()注解

  • 启动实现类,查看日志的打印
    在这里插入图片描述
  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Spring Boot中的CommandLineRunner时,如果发现没有加载,有以下几种可能的原因: 1. 检查注解使用是否正确:在实现类上使用`@Component`或`@Configuration`注解,确保被扫描到并注册为Bean。当CommandLineRunner被作为Spring Boot应用程序中的组件使用时,注解的正确使用非常重要。 2. 检查包扫描配置:如果CommandLineRunner实现类在指定的包或子包中,需要确保包扫描配置正确。在`@SpringBootApplication`注解上,确保指定了正确的`scanBasePackages`或`scanBasePackageClasses`。 3. 检查依赖管理:检查项目的依赖管理和版本是否正确。Spring Boot版本和相关的依赖也可能会影响CommandLineRunner的加载。确保使用的Spring Boot版本和依赖与实现类兼容。 4. 检查Spring Boot配置:在application.properties或application.yml配置文件中,确保没有禁用自动配置或修改了默认配置。有些配置项可能会禁止自动加载CommandLineRunner。 5. 检查其他程序流程:可能在应用程序中的其他组件或配置中,有条件判断或特定的执行流程阻止了CommandLineRunner的加载。检查业务逻辑、AOP切面、条件注解等等。 如果以上方法都没有解决问题,可以尝试在启动应用程序时打印更多的日志信息,通过分析日志来查找加载失败的具体原因。可以使用Spring Boot提供的日志配置,或通过在application.properties或application.yml中添加相关配置项来输出更详细的日志信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值