SpringBoot配置相关(yml文件,多环境配置...)

2024-08-24 17:52

本文主要是介绍SpringBoot配置相关(yml文件,多环境配置...),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SpringBoot配置文件的三种格式

1.application.properties

80端口访问的时候不用写端口

2.application.yml

注意要空一格写值

3.application.yaml

写配置文件没有提示信息的解决方法

配置文件优先级 

application.properties>application.yml>application.yaml

YAML文件

什么是YAML文件?

YAML(YAML Ain't Markup Language),一种数据序列化格式。

YMAL文件扩展名

.yml(主要用这个)

.yaml

语法规则

1.大小写敏感

2.属性层级关系使用多行描述,每行结尾使用冒号结束

3.使用缩进表示层级关系,同层级左侧对齐,只允许使用空格(不允许使用Tab键)。空格的个数并不重要,只要保证同层级的左侧对齐即可。

4.属性值前面添加空格(属性名与属性值之间使用冒号+空格作为分隔)

5. # 表示注释

yml读取数据的三种方式

lesson: springbootPerson:id: 2name: 张三classroom: 4subject:- 语文- 数学- 英语

1.@value读取

2.用Environment读取

先装配Environment ,它会自动读取application.yml

    @Autowiredprivate Environment environment;

 

3.封装对象读取 

将要读取的person封装成一个对象

@Data
@Component //交给Spring管理,后面要装配它
//@ConfigurationProperties 注解表示加载配置文件
//在该注解中也可以使用 prefix 属性指定只加载指定前缀的数据
@ConfigurationProperties(prefix = "person")
public class Person {private int id;private String name;private int classroom;private List<String> subject;
}
3个小问题:
1.需要加入这个依赖才能用@ConfigurationProperties

- 这个依赖有管理元数据的作用。

- 元数据(Metadata)是描述数据的数据,它提供了关于数据的信息,如数据的结构、格式、创建日期、作者等,而不是数据本身的内容

- 这个例子让我们更直观地理解如何从yml中读取数据,但person作为一个实例化对象,用这种方式读取显然是不合理的。

举个例子,我们可以用这种方式来配mysql,我们需要指定数据库,账号密码(这些东西其实就是元数据——描述数据的数据)等等...,然后用一个对象封装起来,在内部定义初始化等一系列必要的操作。springboot项目一启动,我们的数据源就自动配好了。

        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><!--可选依赖--><optional>true</optional></dependency>
2.在Setting中允许使用注解

3. prefix里面不能大写

为了规范,我们把配置文件中的person的p也改成小写(虽然大写也能读出来)

相应的,前面两个例子的p要改成小写

测试

自动装配

    //3.封装对象读取@Autowiredprivate Person person;

测试代码及结果 

//3.封装对象读取
System.out.println(person.getId());
System.out.println(person.getClassroom());
System.out.println(person.getSubject());

多环境配置

yml文件

--- 分隔环境

spring:
  profiles: xxx

设置环境名称为xxx,下面写该环境具体的配置

#默认环境,在这里切换
spring:profiles:active: test---
#开发环境#spring:
#  profiles: dev#不过时的写法
spring:config:activate:on-profile: devserver:port: 80---
#生产环境
spring:profiles: proserver:port: 81---
#测试环境
spring:profiles: testserver:port: 82

测试一下

测试环境的端口是82

 properties文件(了解即可)

ps:properties文件的优先级比yml文件高,测试这个的时候不用注掉yml文件

 命令行启动参数配置

我们的springboot项目打包成jar包给前端的工作人员,里面的环境已经写死了,前端要如何切换环境呢?如果我们配的环境的端口前端都有进程占用了,该如何修改呢?

--------------------------------------------------------------------------------

1.我们的配置文件里面可能会有中文,首先要在Setting中修改编码方式为utf-8

 2.先clean再package,防止前面的打的jar包影响我们此次的测试

3.找到打包好的jar包所在的文件夹

3.1 指定环境为dev环境
java -jar SpringBootProject01-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev

运行结果

是dev环境的80端口,而不是我们yml文件中test环境的82端口 

3.2 指定端口为90端口
java -jar SpringBootProject01-0.0.1-SNAPSHOT.jar --server.port=90

运行结果

3.3 指定dev环境,指定dev环境下的端口为90端口
java -jar SpringBootProject01-0.0.1-SNAPSHOT.jar --server.port=90 --spring.
profiles.active=dev

注意用哪个环境要写在最后面 

运行结果

 springboot配置的优先级

自上而下,优先级从低到高。

配置文件分类

 

target目录下 

ps:

1,2级是开发级别的,3,4级是项目上线级别的。

idea里面启动项目看的是1级  

这篇关于SpringBoot配置相关(yml文件,多环境配置...)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103186

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(