前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2. 配置文件

2. 配置文件

作者头像
捞月亮的小北
发布2023-12-01 10:48:03
1660
发布2023-12-01 10:48:03
举报
文章被收录于专栏:捞月亮的小北

1. 配置文件格式

我们现在启动服务器默认的端口号是 8080​,访问路径可以书写为

代码语言:javascript
复制
http://localhost:8080/books/1

在线上环境我们还是希望将端口号改为 80​,这样在访问的时候就可以不写端口号了,如下

代码语言:javascript
复制
http://localhost/books/1

SpringBoot​ 程序如何修改呢?SpringBoot​ 提供了多种属性配置方式

application.properties

代码语言:javascript
复制
server.port=80

application.yml

代码语言:javascript
复制
server:
	port: 81

application.yaml

代码语言:javascript
复制
server:
	port: 82

注意:​SpringBoot​​ 程序的配置文件名必须是 ​​application​​ ,只是后缀名不同而已。

1.1 三种配合文件的优先级

在三种配合文件中分别配置不同的端口号,启动服务查看绑定的端口号。用这种方式就可以看到哪个配置文件的优先级更高一些

application.properties​ 文件内容如下:

代码语言:javascript
复制
server.port=80

application.yml​ 文件内容如下:

代码语言:javascript
复制
server:
	port: 81

application.yaml​ 文件内容如下:

代码语言:javascript
复制
server:
	port: 82

启动服务,在控制台可以看到使用的端口号是 80​。说明 application.properties​ 的优先级最高

注释掉 application.properties​ 配置文件内容。再次启动服务,在控制台可以看到使用的端口号是 81​,说明 application.yml​ 配置文件为第二优先级。

从上述的验证结果可以确定三种配置文件的优先级是:

application.properties​​ > ​​application.yml​​ > ​​application.yaml

注意: ​SpringBoot​ 核心配置文件名为 application​ ​SpringBoot​ 内置属性过多,且所有属性集中在一起修改,在使用时,通过提示键+关键字修改属性 例如要设置日志的级别时,可以在配置文件中书写 logging​,就会提示出来。配置内容如下 logging: level: root: info

2. ymal 格式

YAML(YAML Ain't Markup Language),一种数据序列化格式。这种格式的配置文件在近些年已经占有主导地位,那么这种配置文件和前期使用的配置文件是有一些优势的,我们先看之前使用的配置文件。

最开始我们使用的是 xml​ ,格式如下:

代码语言:javascript
复制
<enterprise>
    <name>itcast</name>
    <age>16</age>
    <tel>4006184000</tel>
</enterprise>

properties​ 类型的配置文件如下

代码语言:javascript
复制
enterprise.name=itcast
enterprise.age=16
enterprise.tel=4006184000

yaml​ 类型的配置文件内容如下

代码语言:javascript
复制
enterprise:
	name: itcast
	age: 16
	tel: 4006184000

优点:

  • 容易阅读 ​yaml​ 类型的配置文件比 xml​ 类型的配置文件更容易阅读,结构更加清晰
  • 容易与脚本语言交互
  • 以数据为核心,重数据轻格式 ​yaml​ 更注重数据,而 xml​ 更注重格式

YAML 文件扩展名:

  • .yml​ (主流)
  • .yaml

上面两种后缀名都可以,以后使用更多的还是 yml​ 的。

2.1 语法规则

  • 大小写敏感
  • 属性层级关系使用多行描述,每行结尾使用冒号结束
  • 使用缩进表示层级关系​,同层级左侧对齐,只允许使用空格(不允许使用Tab键)​ 空格的个数并不重要,只要保证同层级的左侧对齐即可。
  • 属性值前面添加空格(属性名与属性值之间使用冒号+空格作为分隔)
  • # 表示注释

核心规则:数据前面要加空格与冒号隔开

数组数据在数据书写位置的下方使用减号作为数据开始符号,每行书写一个数据,减号与数据间空格分隔,例如

代码语言:javascript
复制
enterprise:
  name: itcast
  age: 16
  tel: 4006184000
  subject:
    - Java
    - 前端
    - 大数据

3. yaml 配置文件数据读取

3.1 读取配置数据

3.1.1 使用@Value 注解

使用 @Value("表达式")​ 注解可以从配合文件中读取数据,注解中用于读取属性名引用方式是:${一级属性名.二级属性名……}

我们可以在 BookController​ 中使用 @Value​ 注解读取配合文件数据,如下

image
image

3.1.2 Environment 对象

上面方式读取到的数据特别零散,SpringBoot​ 还可以使用 @Autowired​ 注解注入 Environment​ 对象的方式读取数据。这种方式 SpringBoot​ 会将配置文件中所有的数据封装到 Environment​ 对象中,如果需要使用哪个数据只需要通过调用 Environment​ 对象的 getProperty(String name)​ 方法获取。具体代码如下:

image
image

注意:这种方式,框架内容大量数据,而在开发中我们很少使用。

3.1.3 自定义对象

SpringBoot​ 还提供了将配置文件中的数据封装到我们自定义的实体类对象中的方式。具体操作如下:

  • 将实体类 bean​ 的创建交给 Spring​ 管理。 在类上添加 @Component​ 注解
  • 使用 @ConfigurationProperties​ 注解表示加载配置文件 在该注解中也可以使用 prefix​ 属性指定只加载指定前缀的数据
  • BookController​ 中进行注入

具体代码如下:

Enterprise​ 实体类内容如下:

image
image

BookController​ 内容如下:

​​

image
image

​​

注意:

使用第三种方式,在实体类上有如下警告提示

image
image

这个警告提示解决是在 pom.xml​ 中添加如下依赖即可

代码语言:javascript
复制
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-configuration-processor</artifactId>
    <optional>true</optional>
</dependency>

4. 多环境配置

以后在工作中,对于开发环境、测试环境、生产环境的配置肯定都不相同,比如我们开发阶段会在自己的电脑上安装 mysql​ ,连接自己电脑上的 mysql​ 即可,但是项目开发完毕后要上线就需要该配置,将环境的配置改为线上环境的。

image
image

来回的修改配置会很麻烦,而 SpringBoot​ 给开发者提供了多环境的快捷配置,需要切换环境时只需要改一个配置即可。不同类型的配置文件多环境开发的配置都不相同,接下来对不同类型的配置文件进行说明

4.1 yaml 文件

application.yml​ 中使用 ---​ 来分割不同的配置,内容如下

代码语言:javascript
复制
#开发
spring:
  profiles: dev #给开发环境起的名字
server:
  port: 80
---
#生产
spring:
  profiles: pro #给生产环境起的名字
server:
  port: 81
---
#测试
spring:
  profiles: test #给测试环境起的名字
server:
  port: 82
---

上面配置中 spring.profiles​ 是用来给不同的配置起名字的。而如何告知 SpringBoot​ 使用哪段配置呢?可以使用如下配置来启用都一段配置

代码语言:javascript
复制
#设置启用的环境
spring:
  profiles:
    active: dev #表示使用的是开发环境的配置

综上所述,application.yml​ 配置文件内容如下

代码语言:javascript
复制
#设置启用的环境
spring:
  profiles:
    active: dev

---
#开发
spring:
  profiles: dev
server:
  port: 80
---
#生产
spring:
  profiles: pro
server:
  port: 81
---
#测试
spring:
  profiles: test
server:
  port: 82
---

注意:

在上面配置中给不同配置起名字的 spring.profiles​ 配置项已经过时。最新用来起名字的配置项是

代码语言:javascript
复制
#开发
spring:
  config:
    activate:
      on-profile: dev

4.2 properties 文件

properties​ 类型的配置文件配置多环境需要定义不同的配置文件

application-dev.properties​ 是开发环境的配置文件。我们在该文件中配置端口号为 80

代码语言:javascript
复制
server.port=80

application-test.properties​ 是测试环境的配置文件。我们在该文件中配置端口号为 81

代码语言:javascript
复制
server.port=81

application-pro.properties​ 是生产环境的配置文件。我们在该文件中配置端口号为 82

代码语言:javascript
复制
server.port=82

SpringBoot​ 只会默认加载名为 application.properties​ 的配置文件,所以需要在 application.properties​ 配置文件中设置启用哪个配置文件,配置如下:

代码语言:javascript
复制
spring.profiles.active=pro

4.3 命令行启动参数设置

使用 SpringBoot​ 开发的程序以后都是打成 jar​ 包,通过 java -jar xxx.jar​ 的方式启动服务的。那么就存在一个问题,如何切换环境呢?因为配置文件打到的 jar 包中了。

我们知道 jar​ 包其实就是一个压缩包,可以解压缩,然后修改配置,最后再打成 jar 包就可以了。这种方式显然有点麻烦,而 SpringBoot​ 提供了在运行 jar​ 时设置开启指定的环境的方式,如下

代码语言:javascript
复制
java –jar xxx.jar –-spring.profiles.active=test

那么这种方式能不能临时修改端口号呢?也是可以的,可以通过如下方式

代码语言:javascript
复制
java –jar xxx.jar –-server.port=88

当然也可以同时设置多个配置,比如即指定启用哪个环境配置,又临时指定端口,如下

代码语言:javascript
复制
java –jar springboot.jar –-server.port=88 –-spring.profiles.active=test

大家进行测试后就会发现命令行设置的端口号优先级高(也就是使用的是命令行设置的端口号),配置的优先级其实 SpringBoot​ 官网已经进行了说明,参见 :

代码语言:javascript
复制
https://docs.spring.io/spring-boot/docs/current/reference/html/spring-boot-features.html#boot-features-external-config

进入上面网站后会看到如下页面

image
image

5. 配置文件分类

image
image

有这样的场景,我们开发完毕后需要测试人员进行测试,由于测试环境和开发环境的很多配置都不相同,所以测试人员在运行我们的工程时需要临时修改很多配置,如下

代码语言:javascript
复制
java –jar springboot.jar –-spring.profiles.active=test --server.port=85 --server.servlet.context-path=/heima --server.tomcat.connection-timeout=-1 …… …… …… …… ……

针对这种情况,SpringBoot​ 定义了配置文件不同的放置的位置;而放在不同位置的优先级时不同的。

SpringBoot​ 中 4 级配置文件放置位置:

  • 1 级:classpath:application.yml
  • 2 级:classpath:config/application.yml
  • 3 级:file :application.yml
  • 4 级:file :config/application.yml

说明:级别越高优先级越高

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-07-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 配置文件格式
    • 1.1 三种配合文件的优先级
    • 2. ymal 格式
      • 2.1 语法规则
      • 3. yaml 配置文件数据读取
        • 3.1 读取配置数据
          • 3.1.1 使用@Value 注解
          • 3.1.2 Environment 对象
          • 3.1.3 自定义对象
      • 4. 多环境配置
        • 4.1 yaml 文件
          • 4.2 properties 文件
            • 4.3 命令行启动参数设置
            • 5. 配置文件分类
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档