- 名师讲坛:Java微服务架构实战(SpringBoot+SpringCloud+Docker+RabbitMQ)
- 李兴华
- 609字
- 2021-03-26 11:42:20
2.12 profile配置
在项目开发过程中需要考虑不同的运行环境:开发环境(dev)、测试环境(beta)和生产环境(product)。在以往的开发过程中通常使用Maven构建工具进行控制,但却需要进行大量的配置。SpringBoot考虑到此类问题,专门设计了profile支持。
1.【mldnboot-base项目】修改application.yml配置文件,让其支持多profile配置。
在本配置文件中一共定义了3个环境(不同的profile之间使用“---”分割)。
开发环境(profiles=dev、默认):端口定义为7070。
测试环境(profiles=beta):端口定义为8080。
生产环境(profiles=product):端口定义为80。
2.【mldnboot项目】如果要正常进行打包,还需要修改pom.xml文件,追加resource配置。
本程序主要的功能是进行源文件夹中内容的打包输出,配置完成后可以将配置文件打包到*.jar文件中。
3.【mldnboot-base项目】为项目打包,这里直接通过Eclipse进行打包配置(此时无法设置profile),如图2-18所示。
图2-18 项目打包
4.【mldnboot-base项目】项目打包完成后一定要运行程序,如果不做出任何的指派,那么默认配置的活跃profile(dev)就将直接起作用(java -jar mldnboot-base.jar)。
5.【mldnboot-base项目】如果要切换到不同的profile环境,可以在启动时动态配置。
此时在程序运行时将使用product作为运行环境配置。
提示:*.properties与*.yml配置不同。
使用application.yml进行多profile配置的时候,只需要在一个配置文件中使用“---”分割不同的profile配置。但是此类模式不适合于application.properties配置,此时应该采用不同的*.properties保存不同的配置,才可以实现多profile。
范例:定义3个针对不同运行环境的application.properties配置文件。
随后还是需要有一个公共的application.properties配置文件,用于指派可以使用的profile配置。
范例:定义公共的application.properties配置文件。
spring.profiles.active=beta
随后的使用形式与application.yml配置相同。