以spring官方文档为基础,官方地址:Spring Boot
目前官方正式版本最新为:2.5.6(这个学习笔记系列基本是以翻译为主,不用浪费时间期望获取更多。更多是给自己看官方文档做的的一个笔记)
当前篇的内容:介绍官方文档2.5.6的第七章之SpringApplication特性_外化配置
SpringBoot允许配置外部化,即允许使用各种外部配置源,包括Java 属性文件、YAML 文件、环境变量和命令行参数等。
官方建议整个项目最好使用同一种配置格式,且当同一位置同时具有.properties和.yml格式,.properties则优先。
但是当多种配置源同时存在时,存在优先级。以下优先级由低到高,低的会被高的覆盖:
配置文件按照以下顺序(由低到高):
比如,当前指定了profile属性(–spring.profiles.active={profile}),那么相同位置的 application-{profile}.properties优先级大于application.properties的(yaml同样)。
举例来说,假设我们当前执行 java -jar demo.jar –spring.profiles.active=dev,此时application.properties和application-dev.properties文件如下:
application.properties
app.name=MyApp
server.port=8080
application-dev.properties
server.port=8081
那么最终 的server.port 的值为8081,而app.name不会变,被覆盖只有server.port。
Spring查找/加载属性文件的顺序如下:
优先级越来越高,即classpath和当前目录同时存在,那么classpath会被当前目录覆盖。
如果不喜欢application作为配置文件名,你可以通过指定一个fig.name环境属性来切换到另一个文件名。
SpringBoot支持在配置文件中配置随机值,主要是靠RandomValuePropertySource的支持。它可以支持生成int,long,uuid或者字符串。
使用格式为:
my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.uuid=${random.uuid}
my.number-less-than-ten=${random.int(10)}
my.number-in-range=${random.int[1024,65536]}
RandomValuePropertySource截图如下:
通常情况下,我们开发的应用程序需要部署到不同的环境下,属性的配置自然也需要不同。如果每次在发布的时候替换配置文件,过于麻烦。SpringBoot的多环境配置为此提供了便利。具体做法如下:
我们之前在介绍各种配置的优先级的时候说过, application-{profile}.properties或者application-{profile}.yml文件 的优先级高于 application.properties或l 配置,这里的profile就是我们定义的环境标识:
我们在resource目录下创建三个文件:
application.properties:默认的配置,default。
application-dev.properties:开发环境,dev。
application-prod.properties:生产环境,prod。
我们可以通过指定 spring.profiles.active 属性来激活对应的配置环境:
spring.profiles.active=dev
或使用命令行参数的配置形式:
$ java -jar hyh.jar --spring.profiles.active=dev
如果没有profile指定的文件于profile指定的文件的配置属性同时定义,那么指定profile的配置优先。
除了区分配置环境,还可以区分日志打印/Java代码的执行环境。
Java类中@Profile注解。下面2个不同的类实现了同一个接口,@Profile注解指定了具体环境。
// 接口定义
public interface SendMessage {// 发送短信方法定义public void send();}
// Dev 环境实现类
@Component
@Profile("dev")
public class DevSendMessage implements SendMessage {@Overridepublic void send() {System.out.println(">>>>>>>>Dev Send()<<<<<<<<");}}
// Stg环境实现类
@Component
@Profile("stg")
public class StgSendMessage implements SendMessage {@Overridepublic void send() {System.out.println(">>>>>>>>Stg Send()<<<<<<<<");}}
// 启动类
@SpringBootApplication
public class ProfiledemoApplication {@Value("${app.name}")private String name;@Autowiredprivate SendMessage sendMessage;@PostConstructpublic void init(){sendMessage.send();// 会根据profile指定的环境实例化对应的类}}
<?xml version="1.0" encoding="UTF-8"?>
<configuration><include resource="org/springframework/boot/logging/l" /><logger name="org.springframework.web" level="INFO"/><springProfile name="default"><logger name="org.springboot.sample" level="TRACE" /></springProfile><springProfile name="dev"><logger name="org.springboot.sample" level="DEBUG" /></springProfile><springProfile name="staging"><logger name="org.springboot.sample" level="INFO" /></springProfile></configuration>
参考文章:
本文发布于:2024-01-29 00:35:40,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170645974311444.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |