环境介绍
技术栈 | springboot3 |
软件 | 版本 |
mysql | 8 |
IDEA | IntelliJ IDEA 2022.2.1 |
JDK | 17 |
Spring Boot | 3.1.7 |
配置文件说明:启动配置文件优先级:properties高于yml
配置文件application.yml
yml是 JSON 的超集,简洁而强大,是一种专门用来书写配置文件的语言,可以替代 application.properties。
在创建一个 SpringBoot 项目时,引入的 spring-boot-starter-web 依赖间接地引入了 snakeyaml 依赖, snakeyaml 会实现对 yml配置的解析。
yml的使用非常简单,利用缩进来表示层级关系,并且大小写敏感。
yml配置与 Properties 配置的比较
可以使用 @PropertySource 注解加载自定义的 Properties 配置文件,但无法加载自定义的 yml文件。
yml支持列表的配置,而 Properties 不支持。
实体类获取配置文件信息
通过在属性上使用@Value注解,直接将yml文件中的属性值注入到对应的属性中。这种方式适用于需要将yml文件中的属性值注入到单个属性中的情况。
@Value()注解可以用来将外部的值动态注入到Bean中,在@Value注解中,可以使用 ${} 和 #{} 区别
? ? ? ? @Value("${}"): 可以获取对应助兴文件中定义的属性值
? ? ? ? @Value("#{}"):表示SpEl表达式通常来获取bean的属性,或者调用bean的某个方法
@Component
@Data
public class Host {
@Value("${host01.host}")
private String host;
@Value("${host01.port}")
private String port;
@Value("${host01.user}")
private String user;
@Value("${host01.password}")
private String password;
}
加入依赖
<dependency>
? ? ? ? ? ? <groupId>org.springframework.boot</groupId>
? ? ? ? ? ? <artifactId>spring-boot-configuration-processor</artifactId>
? ? ? ? ? ? <optional>true</optional>
</dependency>
Spring源码中大量使用了ConfigurationProperties注解,比如server.port就是由该注解获取到的,通过与其他注解配合使用,能够实现Bean的按需配置。
该注解有一个prefix属性,通过指定的前缀,绑定配置文件中的配置,该注解可以放在类上,也可以放在方法上。当将该注解作用于方法上时,如果想要有效的绑定配置,那么该方法需要有@Bean注解且所属Class需要有@Configuration注解。
Sring的有效运行是通过上下文(Bean容器)中Bean的配合完成的,Bean可以简单理解成对象,有些对象需要指定字段内容,那么这些内容我们可以通过配置文件进行绑定,然后将此Bean归还给容器.
@ConfigurationProperties注解将yml中的值映射到bean的属性上,通过在配置类上使用@ConfigurationProperties注解,将yml文件中的属性值映射到配置类的属性上。这种方式适用于需要将yml文件中的多个属性值映射到一个配置类中的情况。
@Component
@ConfigurationProperties(prefix = "host01")
@Data
public class Host {
//@Value("${host01.host}")
private String host;
//@Value("${host01.port}")
private String port;
//@Value("${host01.user}")
private String user;
//@Value("${host01.password}")
private String password;
}
pom.xml
server:
? port: 8007
management:
? server:
??? port: 8008
? endpoints:
??? web:
????? exposure:
??????? include: "*"
? endpoint:
??? prometheus:
????? enabled: true
??? health:
????? show-details: always
? metrics:
??? export:
????? prometheus:
??????? enabled: true
spring:
? mvc:
??? path match:
????? matching-strategy: ant_path_matcher
? profiles:
??? active: dev
? application:
??? name: ProvideAPIServices
? datasource:
??? dynamic:
????? primary: sys2 #设置默认的数据源或者数据源组,默认值即为master
????? strict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源
????? datasource:
??????? oracle:
????????? username: system
????????? password: 111111
????????? url: jdbc:oracle:thin:@127.0.0.1:.172:1521:orcl
????????? driver-class-name: oracle.jdbc.driver.OracleDriver
#????????? driver-class-name: com.mysql.jdbc.Driver
??????? wms:
????????? url: jdbc:p6spy:mysql://127.0.0.1:3306/Wms?useUnicode=true&characterEncoding=UTF-8
????????? username: root
????????? password: pwd
????????? driver-class-name: com.p6spy.engine.spy.P6SpyDriver
#????????? driver-class-name: com.mysql.jdbc.Driver
??????? sys2:
????????? username: root
????????? password: pwd
????????? url: jdbc:p6spy:mysql://127.0.0.1:3306/sys?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=UTF-8
????????? driver-class-name: com.p6spy.engine.spy.P6SpyDriver
mybatis-plus:
? configuration:
??? #输出日志
??? log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
??? #配置映射规则
??? map-underscore-to-camel-case: true #表示支持下划线到驼蜂的映射
??? #隐藏mybatis图标
? global-config:
??? banner: false
??? db-config:
????? logic-delete-field: status
????? logic-not-delete-value: 1
????? logic-delete-value: 0
#
#mybatis:
#? mapper-locations=classpath: com/example/dao/*.xml
pagehelper:
? propertyName: propertyValue
? reasonable: false
? defaultCount: true # 分页插件默认参数支持 default-count 形式,自定义扩展的参数,必须大小写一致
#主机相关信息
host01:
? host: 192.168.68.133
? port: 22
? user: root
? password: 111111
#邮箱
email:
? user: 123@123
? code: 12314134
? host: 123.qq.com
? auth: true
#爱好
hobbies:
? -打篮球
? -踢足球
? -玩游戏