当前位置: 首页 > news >正文

spring boot设置多环境的配置文件

目录

  • 说明
  • 规划
  • 步骤
  • 案例
    • application.yml
    • application-dev.yml
    • application-test.yml
    • application-prod.yml

说明

在项目开发过程中,回有开发环境、测试环境、生产环境等等。如果所有环境的配置都放在application.yml中并且需要打包到不同的环境中时,修改application.yml同一个文件时会出现遗漏,或者是配置错误的情况。
例如不通过环境下的数据库配置、项目启动的端口号等等。
此时我们可以多创建几个不同环境下的配置文件使用,需要让项目在打包时、运行时 自动去识别需要使用的配置文件。

规划

本案例主要规划为开发环境、测试环境、生产环境。为这三个环境创建三个配置文件。如以下表:

环境文件名称
开发环境application-dev.yml
测试环境application-test.yml
生产环境application-prod.yml

步骤

  1. 项目创建后,创建配置文件,如下:
  • application.yml : springboot项目能识别的配置文件。必须存在。
  • application-dev.yml : 自定义的开发环境配置文件。其中主要配置开发环境中使用的配置内容
  • application-test.yml :自定义的测试环境配置文件。其中主要配置测试环境中使用的配置内容
  • application-prod.yml :自定义的生产环境配置文件。其中主要配置生产环境中使用的配置内容
  1. 修改项目的pom.xml
    在项目的pom.xml中加入以下配置:
 <!-- 配置文件管理 --><profiles><!-- 开发环境使用的配置文件 --><profile><id>dev</id><activation><!-- 默认启动时使用开发环境配置启动 --><activeByDefault>true</activeByDefault></activation><properties><!-- environment 标签为自定义标签,dev值与上面的id标签值一致,且与配置文件名称中的 -dev 一致  environment标签的名称会在application.yml 中使用。--><environment>dev</environment></properties></profile><!-- 测试环境使用的配置文件 --><profile><id>test</id><properties><environment>test</environment></properties></profile><!-- 生产环境使用的配置文件 --><profile><id>prod</id><properties><environment>prod</environment></properties></profile></profiles>

此时idea中的maven中就会出现配置的三个环境的选项。
当我们需要打包或者需要以哪个环境的配置文件启动项目时,再此勾选后运行或者打包项目即可。
在这里插入图片描述
3. 在application.yml 配置中新增加以下的配置

spring:profiles:# 开始和结尾使用@符号# environment为pom.xml中步骤2中配置的自定义标签名称。active: @environment@

案例

application.yml

此配置中可以放三个环境中相同配置的内容

# 项目端口是公共的,即三个环境中配置的端口是一致的,可以放在此配置文件中
server:port: 8081spring:profiles:# 开始和结尾使用@符号# environment为pom.xml中步骤2中配置的自定义标签名称。active: @environment@

application-dev.yml

开发环境下的配置文件

spring:datasource:druid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/zhangDev?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=trueusername: rootpassword: 123456

application-test.yml

测试环境下的配置文件

spring:datasource:druid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.83.156:3306/zhangTest?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=trueusername: rootpassword: ajhbie234

application-prod.yml

生产环境下的配置文件

spring:datasource:druid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://xxx.xx.xxx.xxx:3306/usersystem?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false&allowPublicKeyRetrieval=true&useUnicode=trueusername: userapipassword: ajue@zhang2258

http://www.mrgr.cn/news/25274.html

相关文章:

  • GORM中常见的“reflect: reflect.Value.Set using unaddressable value“错误及解决方案
  • Nginx解决跨域问题
  • JSON对接发送短信验证码怎么获取状态报告
  • 基于Python的可视化在线学习系统
  • 如何进行IP清洗
  • 优化安防视频监控的关键体验:视频质量诊断技术如何应用在监控系统中?
  • Spring面试
  • COMDEL电源维修CLX2500康戴尔射频电源维修
  • 计算机毕业设计 基于SpringBoot的课程教学平台的设计与实现 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试
  • 乐在其中,销赢未来丨eBest 助饮料巨头斩获IDC数字化转型殊荣
  • 【Docker】docker的一些常用命令
  • 知攻善防 Web2 应急靶机笔记
  • 19:I2C一:程序模拟I2C通信时序
  • Java 稀疏数组
  • Windows 的包管理器-Chocolatey
  • Python C++混编程序 PC 测试
  • Doris使用mysql语法查询时只保留group by分组并order by排序出来的每个分组第一条记录的方法
  • 2024软件测试经典面试题,收藏!
  • MySQL 高阶语句
  • 数据库基础知识概述与管理操作指南