SpringBoot实现配置文件自动加载和刷新的示例详解

 更新时间:2023年08月18日 11:07:45   作者:2013crazy  
在使用Spring Boot开发应用程序时,配置文件是非常重要的组成部分,在不同的环境中,我们可能需要使用不同的配置文件,当我们更改配置文件时,我们希望应用程序能够自动加载和刷新配置文件,本文我们将探讨Spring Boot如何实现配置文件的自动加载和刷新

Spring Boot如何实现配置文件的自动加载和刷新?

Spring Boot的配置文件

Spring Boot使用基于属性的配置文件,通常是YAML或Properties格式的文件。这些配置文件包含应用程序的配置信息,例如数据库连接信息、日志配置、端口号等。

在Spring Boot中,配置文件的默认名称为application.yml或application.properties。Spring Boot会在应用程序启动时自动加载这些配置文件,并将它们解析为一个名为Environment的对象。我们可以使用Environment对象获取配置文件中的属性值。

自动加载配置文件

在Spring Boot中,配置文件的自动加载是默认启用的。这意味着当应用程序启动时,Spring Boot会自动加载application.ymlapplication.properties配置文件,并将其转换为Environment对象。我们可以使用@Value注解或Environment对象来获取配置文件中的属性值。

例如,我们可以在application.yml文件中设置应用程序的端口号:

server:
  port: 8080

然后在代码中使用@Value注解获取端口号:

@Value("${server.port}")
private int port;

这样就可以在代码中获取到端口号的值了。

配置文件的刷新

当我们更改配置文件时,我们希望应用程序能够自动加载和刷新配置文件,而无需重启应用程序。Spring Boot提供了两种方式实现配置文件的刷新:基于轮询和基于Webhook。

基于轮询的配置文件刷新

基于轮询的配置文件刷新是Spring Boot默认提供的一种方式。Spring Boot会定期轮询配置文件的修改时间,如果发现配置文件被修改,则会重新加载配置文件。

默认情况下,Spring Boot会每隔5秒钟轮询一次配置文件的修改时间。我们可以通过设置spring.cloud.refresh.interval属性来更改轮询间隔时间。例如,将轮询间隔时间设置为10秒:

spring:
  cloud:
    refresh:
      interval: 10s

在代码中,我们可以使用@RefreshScope注解来标记需要刷新的Bean。当配置文件发生变化时,这些Bean将被重新创建。

例如,我们有一个名为MyService的服务类:

@Service
@RefreshScope
public class MyService {
    @Value("${my.config}")
    private String config;
    // ...
}

当我们更改application.yml文件中的my.config属性时,Spring Boot会自动重新加载配置文件,并重新创建MyService类的实例。在重新创建实例时,config属性的值也将被更新。

基于Webhook的配置文件刷新

基于Webhook的配置文件刷新是另一种实现配置文件刷新的方式。与基于轮询的刷新不同,基于Webhook的刷新方式是在配置文件发生变化时,由另一个应用程序发送HTTP请求通知当前应用程序刷新配置文件。

要启用基于Webhook的配置文件刷新,我们需要引入spring-cloud-starter-config依赖,并在application.ymlapplication.properties配置文件中设置以下属性:

spring:
  cloud:
    config:
      server:
        git:
          uri: <git仓库地址>
          username: <用户名>
          password: <密码>
          search-paths: <配置文件路径>
          clone-on-start: true
      label: <git分支>
      refresh:
        enabled: true

其中,uri属性指定了配置文件所在的Git仓库地址,username和password属性是Git仓库的登录信息,search-paths属性指定了配置文件所在的路径,clone-on-start属性表示在应用程序启动时是否从Git仓库克隆配置文件。label属性指定了Git仓库的分支名称,refresh.enabled属性表示是否启用配置文件的自动刷新。

在配置完成后,我们需要创建一个Webhook来通知应用程序刷新配置文件。我们可以使用GitHub或GitLab等代码托管平台的Webhook功能,将其配置为在配置文件发生变化时向应用程序发送HTTP请求。

当应用程序接收到Webhook请求时,Spring Boot会自动从Git仓库中拉取最新的配置文件并重新加载。我们可以使用@RefreshScope注解来标记需要刷新的Bean,当配置文件发生变化时,这些Bean将被重新创建。

注意事项

在使用配置文件自动刷新功能时,有一些需要注意的事项:

  1. 配置文件中的属性必须使用@Value注解或Environment对象来获取,否则在配置文件刷新后,应用程序中的属性值将不会更新。
  2. 配置文件中的属性必须使用@RefreshScope注解来标记需要刷新的Bean,否则在配置文件刷新后,应用程序中的Bean实例将不会更新。
  3. 在使用基于Webhook的配置文件刷新时,需要注意Git仓库的访问权限和安全性,避免敏感信息泄露。

示例代码

下面是使用Spring Boot实现配置文件自动加载和刷新的示例代码。假设我们有一个名为MyService的服务类,它依赖于配置文件中的my.config属性:

@Service
@RefreshScope
public class MyService{
    @Value("${my.config}")
    private String config;
    public String getConfig() {
        return config;
    }
}

application.yml文件中,我们设置了my.config属性的值为default

my:
  config: default

现在,我们可以使用MyService类的getConfig()方法来获取my.config属性的值。

基于轮询的配置文件刷新

为了演示基于轮询的配置文件刷新,我们将设置轮询间隔时间为10秒,并在10秒后更改my.config属性的值。在application.yml文件中,添加以下配置:

spring:
  cloud:
    refresh:
      interval: 10s

在代码中,我们需要使用@RefreshScope注解标记MyService类,以便在配置文件发生变化时重新创建实例。然后,我们使用一个ScheduledExecutorService定期更改my.config属性的值:

@Service
@RefreshScope
public class MyService {
    @Value("${my.config}")
    private String config;
    public String getConfig() {
        return config;
    }
}
@SpringBootApplication
public class Application {
    private static final ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
   // 定义一个计数器,用于记录更改次数
    private static int count = 0;
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
        // 每隔10秒更改一次my.config属性的值
        executor.scheduleWithFixedDelay(() -> {
            count++;
            String newValue = "value_" + count;
            System.out.println("Changing my.config to " + newValue);
            System.setProperty("my.config", newValue);
        }, 0L, 10L, TimeUnit.SECONDS);
    }
}

在应用程序启动后,MyService类的实例将被创建,并获取my.config属性的值为default。然后,每隔10秒钟,定时任务会更改my.config属性的值,并输出日志。在日志中,我们可以看到每次更改属性值后,MyService类的实例也会重新创建,并获取新的属性值。

基于Webhook的配置文件刷新

为了演示基于Webhook的配置文件刷新,我们需要将配置文件存储在Git仓库中,并配置Webhook通知应用程序刷新配置文件。假设我们将配置文件存储在名为my-config的Git仓库中,分支名称为main,配置文件路径为/config/application.yml。然后,我们需要配置应用程序以从Git仓库中拉取配置文件,并启用配置文件的自动刷新。

application.yml文件中,添加以下配置:

spring:
  cloud:
    config:
      server:
        git:
          uri: <Git仓库地址>
          username: <用户名>
          password: <密码>
          search-paths: /config
      label: main
      refresh:
        enabled: true

其中,uri属性指定了Git仓库的地址,usernamepassword属性是Git仓库的登录信息,search-paths属性指定了配置文件所在的路径。label属性指定了Git仓库的分支名称,refresh.enabled属性表示是否启用配置文件的自动刷新。

在代码中,我们需要使用@RefreshScope注解标记MyService类,以便在配置文件发生变化时重新创建实例。然后,我们可以使用一个@Scheduled注解的方法定期输出my.config属性的值:

@Service
@RefreshScope
public class MyService {
    @Value("${my.config}")
    private String config;
    public String getConfig() {
        return config;
    }
}
@SpringBootApplication
@EnableScheduling
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
    @Autowired
    private MyService myService;
    @Scheduled(fixedRate = 5000)
    public void printConfig() {
        System.out.println("my.config = " + myService.getConfig());
    }
}

在应用程序启动后,MyService类的实例将被创建,并获取my.config属性的值。然后,定时任务将定期输出my.config属性的值。

现在,我们可以在my-config仓库中更改application.yml文件中的my.config属性的值,并推送更改到远程仓库。然后,我们可以在GitHub或GitLab等代码托管平台上配置Webhook,将其配置为在配置文件发生变化时向应用程序发送HTTP请求。当应用程序接收到Webhook请求时,Spring Boot会自动从Git仓库中拉取最新的配置文件,并重新加载。在重新加载配置文件时,MyService类的实例也将被重新创建,并获取新的属性值。我们可以在应用程序的控制台输出中看到,每次更改配置文件后,定时任务输出的my.config属性值也会相应地更新。

总结

在本文中,我们介绍了Spring Boot如何实现配置文件的自动加载和刷新。配置文件是应用程序的重要组成部分,而配置文件的自动加载和刷新可以使应用程序更加灵活和可配置。我们讨论了基于轮询和基于Webhook的配置文件刷新方式,并给出了相应的示例代码。在实践中,我们需要注意一些细节,例如配置文件中属性的获取方式、Bean的刷新方式、Git仓库的访问权限和安全性等。希望本文能够对大家理解Spring Boot的配置文件自动加载和刷新有所帮助。

以上就是SpringBoot实现配置文件自动加载和刷新的示例详解的详细内容,更多关于SpringBoot配置文件自动加载和刷新的资料请关注脚本之家其它相关文章!

相关文章

  • mybatis-plus 处理大数据插入太慢的解决

    mybatis-plus 处理大数据插入太慢的解决

    这篇文章主要介绍了mybatis-plus 处理大数据插入太慢的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • SpringMVC上传图片代码实例

    SpringMVC上传图片代码实例

    这篇文章主要介绍了SpringMVC上传图片代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • 实例讲解Java设计模式编程中如何运用代理模式

    实例讲解Java设计模式编程中如何运用代理模式

    这篇文章主要介绍了Java设计模式编程中如何运用代理模式,文中举了普通代理和强制代理的例子作为代理模式的扩展内容,需要的朋友可以参考下
    2016-02-02
  • Java基础知识总结之继承

    Java基础知识总结之继承

    这一篇我们来学习面向对象的第二个特征——继承,文中有非常详细的基础知识总结,对正在学习java的小伙伴们很有帮助,需要的朋友可以参考下
    2021-06-06
  • java三个环境变量配置简单教程

    java三个环境变量配置简单教程

    这篇文章主要为大家详细介绍了java三个环境变量配置简单教程,配置path变量、配置classpath变量、最后是配置JAVA_HOME变量,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • 关于jackson序列化和feign返回值的问题

    关于jackson序列化和feign返回值的问题

    这篇文章主要介绍了关于jackson序列化和feign返回值的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Spring Boot 2.x 把 Guava 干掉了选择本地缓存之王 Caffeine(推荐)

    Spring Boot 2.x 把 Guava 干掉了选择本地缓存之王 Caffeine(推荐)

    这篇文章主要介绍了Spring Boot 2.x 把 Guava 干掉了选择本地缓存之王 Caffeine,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • SpringBoot+MinIO实现对象存储方式

    SpringBoot+MinIO实现对象存储方式

    这篇文章主要介绍了SpringBoot+MinIO实现对象存储方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • SpringBoot@DeleteMapping(/xxx/{id})请求报405的解决

    SpringBoot@DeleteMapping(/xxx/{id})请求报405的解决

    这篇文章主要介绍了SpringBoot@DeleteMapping(/xxx/{id})请求报405的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • mybatis那些约定的配置你真的都了解吗(经验总结)

    mybatis那些约定的配置你真的都了解吗(经验总结)

    mybatsi中Mapper和xml文件之间有很多约定俗称的规则,比如名称匹配,包扫描,别名等,这些规则是什么。如果想更加灵活,该如何配置呢?今天就给大家讲一下如何配置mybatsi的xml文件
    2021-06-06

最新评论