SpringBoot读取配置文件

本文介绍了SpringBoot项目中外部配置的使用方法,包括配置文件在Jar包内外的启动方式及其问题。针对配置更新不便和配置分散的问题,提出了使用@ConfigurationProperties注解进行优化,增强了代码的可读性和配置的提示功能。同时,文章强调了配置管理的重要性,并提供了配置文件管理和校验的实践建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

最近入职了新公司也接触了几个项目。由于单体项目居多数,生产和测试环境使用外置配置文件的方式启动SpringBoot。虽然在此前也接触过上述启动方式,但在使用操作过程中,也出现了知识盲区,导致在晚上上线的时候耽误了很多时间,并产生误判。综上所述,针对SpringBoot外部参数配置做出如下记录。如果错误欢迎指正,谢谢!

使用

在开始之前,先说说我之前如何启动一个SpringBoot项目的。

配置文件在Jar包内

  1. 当只有一个application.propertiesapplication.yml文件时,项目启动时会读取其中的相关配置;
  2. 针对项目部署环境指定不同的配置文件,例如:application-dev.ymlapplication-test.ymlapplication-prod.yml,在主配置文件application.yml中使用spring.profiles.active指定环境即可;

配置文件在Jar包外

  1. 在启动Jar包时,通过命令行指定配置文件路径,例如:
java -jar app.jar --spring.config.location=/mnt/app/application.yml

存在的问题

  1. 当配置文件在Jar包内,在服务器端部署时需要临时修改某个配置,此时就需要后端开发人员重新打包才可以;
  2. spring.config.location可以指定为文件夹或文件,这里涉及到配置文件合并问题;

针对第一个问题可以在启动的命令中加入指定变量的值,例如:

# 修改启动端口;
java -jar app.jar --server.port=8081

# 修改变量name的值
java -jar app.jar --name='张三'

针对第二个问题就要依据实际情况处理,若将公共配置保存在单独的配置文件,可以指定为文件夹否则指定为具体文件,如下:

# 指定为文件夹下的所有配置文件
java -jar --spring.config.location=/mnt/config/*

# 指定为具体的文件夹
java -jar app.jar --spring.config.location=/mnt/config/application-prod.properties

原理

SpringBoot是如何找到配置文件的

ConfigDataEnvironment类中定义了配置文件应该存放的路径

在这里插入图片描述

以及通过日志查看搜寻记录
在这里插入图片描述

优化及改善

在编写配置文件时,总存在一些自定义配置,例如:

  1. FTP相关配置,host、port等
  2. 开关配置,switch=true
  3. 与对接外部系统的参数配置

上述配置可以通过@Value()注解引入到具体的类中,但在这个过程中,配置零散的分布在不同的类中,且容易出现人为失误(大小写问题),在配置文件中编写时没有提示,造成了不确定性。为了解决这个问题,我个人更推荐使用@ConfigurationProperties注解,以类的形式注入并在编辑配置文件时出现完整的提示。

使用

  1. 添加相关依赖
<dependency>  
 <groupId>org.springframework.boot</groupId>  
 <artifactId>spring-boot-configuration-processor</artifactId>  
 <optional>true</optional>  
</dependency>
  1. 编写配置类
@Getter
@Setter
@Validated
@ConfigurationProperties(prefix = ServerConstant.OSS_PREFIX + CharPool.DOT + "qiniu", ignoreInvalidFields = true)
public class QiNiuOssProperties {
    /**
     * accessKey
     */
    @NotBlank(message = "[accessKey]不可为空")
    private String accessKey;
    /**
     * secretKey
     */
    @NotBlank(message = "[secretKey]不可为空")
    private String secretKey;
    /**
     * bucket
     */
    @NotBlank(message = "[bucket]不可为空")
    private String bucket;

    /**
     * 访问文件的域名
     */
    @NotBlank(message = "[domainOfBucket]不可为空")
    private String domainOfBucket;
}

通过使用@Validated@NotBlank等注解对相关参数进行JSR-303校验,更重要的一点是字段上的注解,这是使配置具有提示功能重要的一步;

完成上述步骤后,执行mvn clean compile后在target/classes/META-INF路径下出现spring-configuration-metadata.json文件, 这就是配置描述文件
在这里插入图片描述

此时,配置文件便拥有了提示功能

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SRXTVM1X-1649150920347)(https://image.haicheng.website/屏幕截图(2)].png)

总结

读取配置文件虽不是高深且复杂的工作,但通过对以上内容的总结,在后续的开发过程中遇到问题,也可以起到查缺补漏的作用;针对相关问题的优化对代码的可读性和可用性有了相应提高。

阅读原文

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值