前言
最近入职了新公司也接触了几个项目。由于单体项目居多数,生产和测试环境使用外置配置文件的方式启动SpringBoot。虽然在此前也接触过上述启动方式,但在使用操作过程中,也出现了知识盲区,导致在晚上上线的时候耽误了很多时间,并产生误判。综上所述,针对SpringBoot外部参数配置做出如下记录。如果错误欢迎指正,谢谢!
使用
在开始之前,先说说我之前如何启动一个SpringBoot项目的。
配置文件在Jar包内
- 当只有一个
application.properties 或application.yml 文件时,项目启动时会读取其中的相关配置; - 针对项目部署环境指定不同的配置文件,例如:
application-dev.yml 、application-test.yml 和application-prod.yml ,在主配置文件application.yml 中使用spring.profiles.active 指定环境即可;
配置文件在Jar包外
- 在启动Jar包时,通过命令行指定配置文件路径,例如:
java -jar app.jar --spring.config.location=/mnt/app/application.yml
存在的问题
- 当配置文件在Jar包内,在服务器端部署时需要临时修改某个配置,此时就需要后端开发人员重新打包才可以;
spring.config.location 可以指定为文件夹或文件,这里涉及到配置文件合并问题;
针对第一个问题可以在启动的命令中加入指定变量的值,例如:
java -jar app.jar --server.port=8081
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 类中定义了配置文件应该存放的路径
以及通过日志查看搜寻记录
优化及改善
在编写配置文件时,总存在一些自定义配置,例如:
- FTP相关配置,host、port等
- 开关配置,
switch=true - 与对接外部系统的参数配置
上述配置可以通过@Value() 注解引入到具体的类中,但在这个过程中,配置零散的分布在不同的类中,且容易出现人为失误(大小写问题),在配置文件中编写时没有提示,造成了不确定性。为了解决这个问题,我个人更推荐使用@ConfigurationProperties 注解,以类的形式注入并在编辑配置文件时出现完整的提示。
使用
- 添加相关依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
- 编写配置类
@Getter
@Setter
@Validated
@ConfigurationProperties(prefix = ServerConstant.OSS_PREFIX + CharPool.DOT + "qiniu", ignoreInvalidFields = true)
public class QiNiuOssProperties {
@NotBlank(message = "[accessKey]不可为空")
private String accessKey;
@NotBlank(message = "[secretKey]不可为空")
private String secretKey;
@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)
总结
读取配置文件虽不是高深且复杂的工作,但通过对以上内容的总结,在后续的开发过程中遇到问题,也可以起到查缺补漏的作用;针对相关问题的优化对代码的可读性和可用性有了相应提高。
阅读原文
|