一、引言
在上一篇文章中,我们开启了Spring Boot的入门之旅,成功构建了第一个Spring Boot应用。我们从环境搭建开始,详细介绍了JDK的安装以及IDE的选择与配置,然后利用Spring Initializr创建了项目,分析了项目结构,还编写了第一个简单的API并深入理解了自动配置。这一系列的操作让我们初步领略了Spring Boot在快速构建Java应用方面的强大能力。
配置文件就像是Spring Boot应用的指挥中心,它掌控着应用的各种设置。无论是定义服务器的运行参数,还是连接数据库的详细信息,又或是自定义的业务逻辑相关的属性,都离不开配置文件。合理地配置这些文件,可以让我们的应用在不同的环境(如开发环境、测试环境、生产环境)中灵活运行,同时也方便我们对应用进行定制化和维护。
二、Spring Boot配置文件的类型
1. application.properties
文件
- 基本语法和格式
application.properties
文件采用键值对(key - value)的形式来设置配置项。每一行代表一个配置项,格式为key=value
。例如,要设置服务器的端口号为8080,可以写成server.port=8080
。这里的server.port
就是键(key),8080
就是值(value)。键是固定的配置项名称,Spring Boot会根据这些键来识别对应的配置内容。值则根据具体的配置需求而定,可以是数字、字符串、布尔值等不同的数据类型。- 对于一些复杂的值,如列表或者映射,可能需要使用特定的格式。例如,要配置一个包含多个数据源的列表,可以使用逗号分隔的值,像
spring.datasource.url=jdbc:mysql://localhost:3306/db1,jdbc:mysql://localhost:3306/db2
。
- 常见配置项示例(如服务器端口、数据库连接等)
- 服务器端口配置:除了上面提到的
server.port
,我们还可以配置服务器的上下文路径。例如,server.servlet.context - path=/myapp
,这意味着我们的应用将在http://localhost:8080/myapp
这个路径下运行。 - 数据库连接配置:假设我们使用MySQL数据库,配置数据库连接的相关项包括
spring.datasource.url=jdbc:mysql://localhost:3306/mydb
(数据库的URL),spring.datasource.username=root
(数据库用户名),spring.datasource.password=123456
(数据库密码),spring.datasource.driver - class - name=com.mysql.cj.jdbc.Driver
(数据库驱动类名)。这些配置项告诉Spring Boot如何连接到指定的数据库。
- 服务器端口配置:除了上面提到的
2. application.yml
文件
- YAML语法介绍
- YAML(YAML Ain’t Markup Language)是一种简洁的数据序列化格式。它使用缩进表示层级关系,而不是像
application.properties
那样使用点号(.)。在YAML中,基本的数据结构有标量(如字符串、数字、布尔值)、列表和映射。 - 字符串不需要使用引号包裹,除非字符串中包含特殊字符或者空格。例如,
name: John
是合法的字符串配置。对于布尔值,true
和false
直接书写即可,如enabled: true
。 - 列表使用短横线(-)开头,每个元素占一行。例如:
- YAML(YAML Ain’t Markup Language)是一种简洁的数据序列化格式。它使用缩进表示层级关系,而不是像
fruits:
- apple
- banana
- cherry
- 映射是键值对的集合,通过缩进表示层级关系。例如:
person:
name: Tom
age: 25
address:
city: New York
street: 123 Main St
- 对比
application.properties
,展示YAML的简洁性- 以配置服务器端口和数据库连接为例,在
application.properties
中我们需要这样写:
- 以配置服务器端口和数据库连接为例,在
server.port=8080
spring.datasource.url=jdbc:mysql://localhost:3306/mydb
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver - class - name=com.mysql.cj.jdbc.Driver
- 在
application.yml
中可以写成:
server:
port: 8080
spring:
datasource:
url: jdbc:mysql://localhost:3306/mydb
username: root
password: 123456
driver - class - name: com.mysql.cj.jdbc.Driver
- 可以看到,YAML格式更加直观,尤其是对于复杂的嵌套结构,YAML的可读性更强。
- 转换application.properties
中的配置到application.yml
- 假设我们有一个
application.properties
文件中的配置如下:
- 假设我们有一个
myapp.title=My Awesome App
myapp.version=1.0
myapp.settings.enabled=true
myapp.settings.timeout=30
- 转换为
application.yml
文件的配置如下:
myapp:
title: My Awesome App
version: 1.0
settings:
enabled: true
timeout: 30
三、自定义配置属性
1. 创建自定义配置类
- 使用
@ConfigurationProperties
注解- 首先,我们创建一个Java类来表示我们的自定义配置。例如,我们创建一个名为
AppConfig
的类。在这个类中,我们可以定义各种属性来接收配置文件中的值。假设我们要配置一个邮件服务相关的设置,我们可以这样写:
- 首先,我们创建一个Java类来表示我们的自定义配置。例如,我们创建一个名为
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix = "mail")
public class AppConfig {
private String host;
private int port;
private boolean enabled;
public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public int getPort() {
return port;
}
public void setPort(int port) {
this.port = port;
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
}
- 这里的
@ConfigurationProperties
注解的prefix
属性指定了在配置文件中对应的配置项的前缀。例如,在application.yml
文件中,我们可以这样配置邮件服务:
mail:
host: smtp.example.com
port: 25
enabled: true
- 定义属性并设置默认值
- 我们可以在自定义配置类中为属性设置默认值。例如,修改上面的
AppConfig
类:
- 我们可以在自定义配置类中为属性设置默认值。例如,修改上面的
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix = "mail")
public class AppConfig {
private String host = "smtp.default.com";
private int port = 25;
private boolean enabled = false;
// 省略getter和setter方法
}
- 这样,如果在配置文件中没有配置
mail.host
、mail.port
或者mail.enabled
,那么就会使用默认值。
2. 在配置文件中设置自定义属性的值
- 不同数据类型(字符串、数字、布尔值等)的配置示例
- 字符串类型:继续以邮件服务为例,如果要配置邮件的发件人地址,我们可以在
application.yml
中添加如下配置:
- 字符串类型:继续以邮件服务为例,如果要配置邮件的发件人地址,我们可以在
mail:
sender: [email protected]
- 在
AppConfig
类中添加一个private String sender;
属性以及对应的getter
和setter
方法,就可以接收这个配置值了。- 数字类型:假设我们要配置邮件发送的最大重试次数,在
application.yml
中:
- 数字类型:假设我们要配置邮件发送的最大重试次数,在
mail:
max - retry - times: 3
- 在
AppConfig
类中添加private int maxRetryTimes;
属性和相应的方法。 - 布尔值类型:如果要配置是否开启邮件的加密传输,在
application.yml
中:
mail:
use - ssl: true
- 在
AppConfig
类中添加private boolean useSsl;
属性和相关方法。
- 多层嵌套属性的配置- 假设我们的邮件服务有更复杂的配置,比如不同类型邮件(如通知邮件、营销邮件)的发送设置。我们可以这样在
application.yml
中配置:
- 假设我们的邮件服务有更复杂的配置,比如不同类型邮件(如通知邮件、营销邮件)的发送设置。我们可以这样在
mail:
notification:
subject - prefix: "[Notification]"
enabled: true
marketing:
subject - prefix: "[Marketing]"
enabled: false
- 在
AppConfig
类中,我们可以创建内部类来接收这些嵌套的配置:
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix = "mail")
public class AppConfig {
private NotificationConfig notification;
private MarketingConfig marketing;
public NotificationConfig getNotification() {
return notification;
}
public void setNotification(NotificationConfig notification) {
this.notification = notification;
}
public MarketingConfig getMarketing() {
return marketing;
}
public void setMarketing(MarketingConfig marketing) {
this.marketing = marketing;
}
public static class NotificationConfig {
private String subjectPrefix;
private boolean enabled;
public String getSubjectPrefix() {
return subjectPrefix;
}
public void setSubjectPrefix(String subjectPrefix) {
this.subjectPrefix = subjectPrefix;
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
}
public static class MarketingConfig {
private String subjectPrefix;
private boolean enabled;
public String getSubjectPrefix() {
return subjectPrefix;
}
public void setSubjectPrefix(String subjectPrefix) {
this.subjectPrefix = subjectPrefix;
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
}
}
四、配置文件的加载顺序
1. 不同位置的配置文件加载优先级
- 项目根目录下的配置文件
- 当Spring Boot应用启动时,它会首先查找项目根目录下的
application.properties
或者application.yml
文件。这个位置的配置文件具有较高的优先级,可以用于覆盖默认的配置。例如,如果我们在项目根目录下的application.yml
中设置了server.port=8090
,那么这个配置将会优先于其他位置的相同配置项被加载。
- 当Spring Boot应用启动时,它会首先查找项目根目录下的
- 类路径下的配置文件
- 如果项目根目录下没有找到配置文件,Spring Boot会在类路径(classpath)下查找
application.properties
或者application.yml
文件。类路径下的配置文件是默认的配置来源。通常,我们在创建Spring Boot项目时,在resources
文件夹下的application.yml
或者application.properties
就是类路径下的配置文件。这里的配置项会被加载,如果项目根目录下没有覆盖这些配置的话。
- 如果项目根目录下没有找到配置文件,Spring Boot会在类路径(classpath)下查找
- 外部配置文件(如通过命令行指定)
- Spring Boot还支持通过命令行指定外部配置文件。例如,我们可以在启动应用时使用
--spring.config.location=file:/path/to/external - config/application.yml
这样的命令行参数来指定外部配置文件的位置。外部配置文件的优先级最高,它可以覆盖项目根目录和类路径下的相同配置项。
- Spring Boot还支持通过命令行指定外部配置文件。例如,我们可以在启动应用时使用
2. 利用加载顺序进行灵活配置
- 覆盖默认配置的示例
- 假设我们在类路径下的
application.yml
中有默认的数据库连接配置:
- 假设我们在类路径下的
spring:
datasource:
url: jdbc:mysql://localhost:3306/defaultdb
username: defaultuser
password: defaultpassword
- 在开发环境中,我们可能需要连接到本地的测试数据库。我们可以在项目根目录下创建一个
application.yml
文件,只包含需要覆盖的配置项:
spring:
datasource:
url: jdbc:mysql://localhost:3306/testdb
username: testuser
password: testpassword
这样,当在开发环境中启动应用时,就会使用项目根目录下的配置文件中的数据库连接配置,而不是类路径下的默认配置。
五、配置文件与不同环境(dev、prod等)
1. 多环境配置的概念
- 为什么需要多环境配置
- 在软件开发过程中,我们通常会经历多个不同的环境,如开发环境(dev)、测试环境(test)、生产环境(prod)等。不同的环境可能需要不同的配置。例如,在开发环境中,我们可能使用本地的轻量级数据库,并且日志级别设置为
DEBUG
以便于调试;而在生产环境中,我们会使用正式的数据库服务器,并且日志级别可能设置为INFO
或者WARN
以减少日志输出量,提高性能。多环境配置可以让我们在不同的环境中轻松切换应用的配置,而不需要频繁地修改配置文件中的具体内容。
- 在软件开发过程中,我们通常会经历多个不同的环境,如开发环境(dev)、测试环境(test)、生产环境(prod)等。不同的环境可能需要不同的配置。例如,在开发环境中,我们可能使用本地的轻量级数据库,并且日志级别设置为
2. 使用配置文件实现多环境配置
- 基于
application - {env}.properties/yml
的配置- 在Spring Boot中,我们可以使用
application - {env}.properties
或者application - {env}.yml
的方式来进行多环境配置。例如,我们有一个开发环境的配置文件application - dev.yml
和一个生产环境的配置文件application - prod.yml
。 - 在
application - dev.yml
中,我们可以配置适合开发环境的设置,如:
- 在Spring Boot中,我们可以使用
server:
port: 8081
spring:
datasource:
url: jdbc:mysql://localhost:3306/devdb
username: devuser
password: devpassword
profiles:
active: dev
logging:
level:
root: DEBUG
- 在
application - prod.yml
中,配置适合生产环境的设置:
server:
port: 80
spring:
datasource:
url: jdbc:mysql://prod - db - server:3306/proddb
username: produser
password: prodpassword
profiles:
active: prod
logging:
level:
root: INFO
- 激活不同环境的方式(如通过命令行参数、系统环境变量)
- 通过命令行参数:我们可以在启动应用时使用
--spring.profiles.active=dev
或者--spring.profiles.active=prod
这样的命令行参数来激活对应的环境配置。例如,java - jar myapp.jar --spring.profiles.active=dev
会激活开发环境的配置。 - 通过系统环境变量:我们也可以设置系统环境变量
SPRING_PROFILES_ACTIVE
的值来激活环境。例如,在Linux系统中,我们可以使用export SPRING_PROFILES_ACTIVE=prod
来设置环境变量,然后启动应用时就会使用生产环境的配置。
- 通过命令行参数:我们可以在启动应用时使用
六、总结与展望
在这篇文章中,我们深入探讨了Spring Boot中的配置文件。我们了解了两种主要的配置文件类型application.properties
和application.yml
,它们各自的语法和特点,以及如何相互转换。我们还学习了如何创建自定义配置属性,通过@ConfigurationProperties
注解来实现配置与Java类的绑定。同时,我们明白了配置文件的加载顺序,以及如何利用这个顺序进行灵活的配置覆盖。最后,我们掌握了多环境配置的方法,通过application - {env}.properties/yml
的方式和不同的激活环境的手段(命令行参数、系统环境变量),可以让我们的应用在不同的环境中顺利运行。
在下一篇文章中,我们将进入Spring Boot与数据库集成的精彩世界。我们会探讨如何选择适合我们应用的数据库,如何在Spring Boot项目中添加数据库相关的依赖,如何进行数据库连接配置,以及如何使用JPA(Java Persistence API)进行数据持久化等重要内容。这将为我们构建数据驱动的应用奠定坚实的基础。