SpringBoot 配置文件

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: SpringBoot 配置文件


配置文件的作用

       整个项目中所有重要的数据都是在配置文件中配置的, 例如:

  • 数据库的连接信息, 包括用户名和密码的设置
  • 项目的启动端口
  • 第三方系统的调用密钥等信息
  • 用于发现和定位问题的普通日志和异常日志等

       想象一下如果没有配置信息, 那么springBoot项目就不能连接和操作数据库, 甚至是不能保存可以用于排查问题的日志, 所以配置文件是非常重要的.

配置文件的格式

       配置文件spring boot分为以下两种:

  1. .properties
  2. .yml

       如下图所示:

       可以类比一下服装店的服装一样, 有两种不同的款式, properties相当于老款式, yml相当于新款式.

        理论上将properties可以和yml一起存在于一个项目当中, 当properties和yml在一起的时候, 如果配置文件中出现了同样的配置, 比如properties和yml中都配置了server.port, 那么这个时候会以properties为主, 也就是properties的配置文件的优先级最高, 但是加载完.properties文件之后也会加载yml文件的配置信息

       虽然理论上将properties可以和yml共存, 但实际业务当中, 我们通常会采用一种统一的配置文件格式, 这样可以更好的维护.

.properties文件说明

基本语法

       properties是以键值对的形式配置的, key 和 value之间是以 "=" 连接的, 例如:

server.port=8088
spring.datasource,url=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=2222

       配置文件中使用#来添加注释

读取配置文件

        如果在项目中, 想要主动的读取配置文件中的内容, 可以使用@Value注解来实现, @Value注解使用${} 的格式来读取, 如下代码:

package com.example.demo1.Test;
 
import jakarta.annotation.PostConstruct;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
 
@Component
public class TestValue {
    @Value("${server.port}")
    private String port;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println("Read server port : " + port);
    }
}

       启动项目, 如下:

       @Component 在springboot启动的时候会注入到框架当中, 注入到框架中会执行@PostConstruct初始化方法, 这个时候就会在控制台输出这个配置信息了.

缺点分析

       properties配置文件中的配置是以键值对的形式出现的, 也就是key-value形式出现的, 可以对比java集合体系中的map, 如下图所示:

       在书写的时候, 难免会出现很多冗余字段, 例如:

.yml 配置文件说明

        yml是YAML的缩写, 全称为yet another markup language, 中文示意为另外一种标记语言

优点分析

  • yml是一个可读性高, 写法简单, 易于理解, 它的语法和JSON类似
  • yml支持多种数据类型, 他可以简单表达清单, 也就是数组, 散列表, 标量等数据形态,它使用空白符号缩进和大量依赖外观的特色, 特别适合用来表达或编辑数据结构, 各种配置文件
  • yml 支持更多的编程语言, 它不只是java , 还可以使用在golang, php, python, ruby js, perl中

基本语法

       yml是树形结构的配置文件, 它的基础语法是key: value, 注意这里的冒号和value之间有一个空格, 这个空格是不能省略的.

       基础语法如下:

# 正确的配置方式
String: java
 
# 错误的配
string2:mysql

       显示无效子元素

使用yml连接数据库

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8
    username: root
    password: 2222

和properties配置连接数据库进行对比:

server.port=8088
spring.datasource,url=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=2222

       可以看见properties配置文件中有很多冗余项

yml配置不同数据类型及null

# 字符串
string.value: hello
 
# boolean: true or false
boolean.value: true
boolean.value2: false
 
# 整数
int.value: 12
int.value2: 0b1010_0111_1100_1111 # 二进制
 
# 浮点数
float.value: 3.1415926
float.value2: 31415926e-7 # 科学计数法
 

        表示null:

null.value: ~

yml配置读取

       同样使用@Value("${value}") 来读取:

       定义字符串:

       进行读取:

package com.example.demo1.Test;
 
import jakarta.annotation.PostConstruct;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
 
@Component
public class TestValue {
    @Value("${string.value}")
    private String value;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println("read yml string.value : " + value);
    }
}

        启动项目, 输出:

        尝试读取null.value: ~,  读取为null的配置和根本不存在的配置结果是否一致?

设置null:

null.value: ~

读取null.value

package com.example.demo1.Test;
 
import jakarta.annotation.PostConstruct;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
 
@Component
public class TestValue {
    @Value("${null.value}")
    private String value;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println("read yml null.value : " + value);
    }
}

       输出:

       通过调试发现, 获取的null.value为空字符串:

value值加单双引号

        在配置文件中, 字符串时默认不用加上单双引号的, 如果加英文的单引号可以表示特殊含义.

       例如尝试在application.yml中配置如下数组:

string:
  str1: hello \n world
  str2: 'hello \n world'
  str3: "hello \n world"

       进行读取, 代码如下:

package com.example.demo1.Test;
 
import jakarta.annotation.PostConstruct;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
 
@Component
public class TestValue {
 
    @Value("${string.str1}")
    private String str1;
 
    @Value("${string.str2}")
    private String str2;
 
    @Value("${string.str3}")
    private String str3;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println("read str1:" + str1);
        System.out.println("read str2:" + str2);
        System.out.println("read str3:" + str3);
    }
}

       输出如下:

       从上述结果可以看出:

  • 字符串不需要加上单双引号
  • 单引号会转义特殊字符, 特殊字符最终变成一个普通的字符串
  • 双引号不会引起转义字符转义, 会表现出来特殊字符本来的意思

yml对象

       对应java中的类, yml也可以配置对象, 例如下面配置一个Student对象:

stduent:
  id: 2323
  name: zhangSan
  age: 18

       或者是写在一行, 使用{} 来表示:

student2: {id: 2323,name: zhangSan,age: 18}

       这个时候就不能使用@Value来读取对象了, 需要使用@ConfigurationProperties 来读取, 具体实现如下:

package com.example.demo1.Test;
 
 
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
 
@ConfigurationProperties(prefix = "student")
@Component
public class Student {
    private int id;
    private String name;
    private int age;
 
    public int getId() {
        return id;
    }
 
    public void setId(int id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public int getAge() {
        return age;
    }
 
    public void setAge(int age) {
        this.age = age;
    }
 
    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

(注意这里的get和set方法不可以省略)

       读取到yml中的配置文件之后, 就会注入此类对象. 然后再属性注入给下面的类:

package com.example.demo1.Test;
 
import jakarta.annotation.PostConstruct;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
 
@Component
public class TestValue {
 
    @Autowired
    private Student student;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println(student.toString());
    }
}

输出--

yml配置集合类

       例如如下代码:

listTable:
  name:
    - zhangsan
    - lisi
    - wangwu

        或者使用同一行的写法:

listTable2: {name: [zhangsan,lisi,wangwu]}

       集合的读取和对象的读取是一样的, 同样是使用@ConfigurationProperties来读取, 具体实现如下:

@Component
@ConfigurationProperties(prefix = "listtable")
public class ListTable {
    private List<String> name;
 
    public List<String> getName() {
        return name;
    }
 
    public void setName(List<String> name) {
        this.name = name;
    }
}

       通过属性注入给:

@Component
public class TestValue {
 
    @Autowired
    private ListTable listTable;
 
    @PostConstruct
    public void postConstruct() {
        System.out.println(listTable.getName());
    }
}

启动项目, 输出如下--

properties VS yml

  • properties 是以key=value的形式配置的, 而yml使用的是类似json的格式树形结构进行配置的,yml之间层级使用换行缩进的形式配置, key和value之间使用:间隔, 同时:后面需要有一个空格
  • properties 为早期并且为默认的配置文件格式, 但其配置存在一定的冗余数据, 使用yml可以很好的解决数据冗余的问题
  • yml通用性更好, 支持更多的语言, java, go, Python等, 如果是云服务器开发, 可以使用一份配置文件作为java和go的共同配置文件
  • yml支持更多的数据类型

SpringBoot 有几种读取配置文件的方法?

Spring Boot 中读取配置文件有以下 5 种方法:

  1. 使用 @Value 读取配置文件。
  2. 使用 @ConfigurationProperties 读取配置文件。
  3. 使用 Environment 读取配置文件。
  4. 使用 @PropertySource 读取配置文件。
  5. 使用原生方式读取配置文件。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7月前
|
Java
SpringBoot基础配置文件
SpringBoot基础配置文件
|
8月前
|
Java 测试技术 Spring
SpringBoot 配置文件
SpringBoot 配置文件
|
8月前
|
Java 测试技术 数据库连接
SpringBoot 及 配置文件
SpringBoot 及 配置文件
springboot优雅的获取yml配置
springboot优雅的获取yml配置
154 0
|
8月前
|
Java 数据库 Spring
SpringBoot配置文件(一)
SpringBoot配置文件
102 0
SpringBoot配置文件(一)
|
8月前
|
JSON Java Go
|
XML JavaScript Java
SpringBoot的配置文件(上)
SpringBoot的配置文件(上)
102 0
|
存储 机器学习/深度学习 Java
SpringBoot的配置文件(下)
SpringBoot的配置文件(下)
|
JSON Java 数据库连接
SpringBoot【配置文件】(上)
SpringBoot【配置文件】(上)
SpringBoot【配置文件】(上)
|
JSON JavaScript Java
SpringBoot【配置文件】(下)
SpringBoot【配置文件】(下)
SpringBoot【配置文件】(下)