背景
spring cloud config server从远古版本升级到3.1.2(对应的spring cloud版本为2021.0.2)后,客户端读取配置失败,服务端报错
exception is org.springframework.boot.context.config.InvalidConfigDataPropertyException: Property ‘spring.profiles.active’ imported from location 'file … …
google报错后发现,对于激活profile的配置包括(spring.profiles.active、spring.profiles.include等),从spring boot2.4开始,不在支持在xx-{profile}.properties( profile-specific document)中配置。
详细参考
https://github.com/spring-projects/spring-boot/wiki/Spring-Boot-Config-Data-Migration-Guide
https://spring.io/blog/2020/08/14/config-file-processing-in-spring-boot-2-4?spm=a2c6h.12873639.article-detail.9.77782670meHVIG
解决方案
在application.properties中配置spring.config.use-legacy-processing=true
spring后面可能会去掉对老的配置方式的支持,所以通过改配置项临时解决问题后,后面最好还是按照最新的规则,对存量的配置进行修改。
其他不兼容点
除了不支持在profile-specific document中配置spring.profiles.active、spring.profiles.include外,spring cloud config server返回的参数优先级也有所改变。
比如:
客户端的配置的参数如下:
spring.cloud.config.name=APP
spring.cloud.config.profile=test
服务端APP.properties文件内容为:
spring.profiles.include=mysql,redis,client
升级前文件的优先级为
优先级 | 文件名 |
---|---|
1 | APP-test.properties |
2 | APP-client.properties |
3 | APP-redis.properties |
4 | APP-mysql.properties |
5 | APP.properties |
升级后的优先级为
优先级 | 文件名 |
---|---|
1 | APP-client.properties |
2 | APP-redis.properties |
3 | APP-mysql.properties |
4 | APP-test.properties |
5 | APP.properties |