zoukankan      html  css  js  c++  java
  • Spring Boot 启动以后然后再加载缓存数据 CommandLineRunner

    实际应用中,我们会有在项目服务启动完成以后去加载一些数据或做一些事情(比如缓存)这样的需求。
    为了解决这样的问题,Spring Boot 为我们提供了一个方法,通过实现接口 CommandLineRunner 来实现。

    很简单,只需要一个类就可以,无需其他配置。
    创建实现接口 CommandLineRunner 的类

         @Bean
        public CommandLineRunner newEnumDataPreloadRunner() {
            return new EnumDataPreloadRunner();
        }
    
    @Slf4j
    public class EnumDataPreloadRunner implements CommandLineRunner {
    
        @Resource
        private EnumDataUtil enumDataUtil;
    
        @Override
        public void run(String... args) throws Exception {
            CompletableFuture.runAsync(() -> log.info("preload over... types={}", this.enumDataUtil.refresh()))
                    .toCompletableFuture();
        }
    
    }
    

      

    Spring Boot应用程序在启动后,会遍历CommandLineRunner接口的实例并运行它们的run方法。也可以利用@Order注解(或者实现Order接口)来规定所有CommandLineRunner实例的运行顺序。

    如下我们使用@Order 注解来定义执行顺序。

    package org.springboot.sample.runner;
    
    import org.springframework.boot.CommandLineRunner;
    import org.springframework.core.annotation.Order;
    import org.springframework.stereotype.Component;
    
    /**
    * 服务启动执行
    */
    @Component
    @Order(value=2)
    public class MyStartupRunner1 implements CommandLineRunner {
    
    @Override
    public void run(String... args) throws Exception {
    System.out.println(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 11111111 <<<<<<<<<<<<<");
    }
    
    }
    
    package org.springboot.sample.runner;
    
    import org.springframework.boot.CommandLineRunner;
    import org.springframework.core.annotation.Order;
    import org.springframework.stereotype.Component;
    
    /**
    * 服务启动执行
    */
    @Component
    @Order(value=1)
    public class MyStartupRunner2 implements CommandLineRunner {
    
    @Override
    public void run(String... args) throws Exception {
    System.out.println(">>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 22222222 <<<<<<<<<<<<<");
    }
    
    }


    启动程序后,控制台输出结果为:

    >>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 22222222 <<<<<<<<<<<<<
    >>>>>>>>>>>>>>>服务启动执行,执行加载数据等操作 11111111 <<<<<<<<<<<<<


    根据控制台结果可判断,@Order 注解的执行优先级是按value值从小到大顺序。

  • 相关阅读:
    hadoop yarn日志分离
    hadoop优化
    hive UDF
    hadoophttpfs
    spark编译
    spark feature
    python
    python 装饰器
    HTML特殊转义字符列表
    博客园数据统计
  • 原文地址:https://www.cnblogs.com/baizhanshi/p/11003330.html
Copyright © 2011-2022 走看看