我们在开发Spring Boot应⽤时,通常同⼀套程序会被应⽤和安装到⼏个不同的环境,比如:开发、测试、生产等。其中每个环境的数据库地址、服务器端⼝等等配置都会不同,如果在为不同环境打包时 都要频繁修改配置⽂件的话,那必将是个⾮常繁琐且容易发⽣错误的事。
对于多环境的配置,各种项⽬构建⼯具或是框架的基本思路是⼀致的,通过配置多份不同环境的配置 ⽂件,再通过打包命令指定需要打包的内容之后进⾏区分打包,Spring Boot也不例外,或者说更加简单。
在Spring Boot中多环境配置⽂件名需要满足application-{profile}.properties的格式,其中{profile}对应你的环境标识,比如:
application-dev.properties :开发环境
application-test.properties :测试环境
application-prod.properties :⽣产环境
⾄于哪个具体的配置⽂件会被加载,需要在 application.properties ⽂件中通过 spring.profiles.active
属性来设置,其值对应 {profile} 值。
如: spring.profiles.active=test 就会加载 application-test.properties 配置⽂件内容
下⾯,以不同环境配置不同的服务端⼝为例,进⾏样例实验。
- 针对各环境新建不同的配置⽂件 application-dev.properties 、 application-test.properties 、 application-prod.properties
- 在这三个⽂件均都设置不同的 server.port 属性,如:dev环境设置为1111,test环境设置为2222,prod环境设置为3333
- application.properties中设置 spring.profiles.active=dev ,就是说默认以dev环境设置
- 测试不同配置的加载
- 执⾏ java -jar xxx.jar ,可以观察到服务端⼝被设置为 1111 ,即默认的开发环境(dev)
- 执⾏ java -jar xxx.jar --spring.profiles.active=test ,可以看到服务端⼝被设置为 2222 ,即测试环境的配置(test)
- 执⾏ java -jar xxx.jar --spring.profiles.active=prod ,可以看到服务端⼝被设置为 3333 ,即⽣产环境的配置(prod)
按照上⾯的实验,可以如下总结多环境的配置思路:
- application.properties 中配置通⽤内容,并设置 spring.profiles.active=dev ,以开发环境为默认配置
- application-{profile}.properties 中配置各个环境不同的内容
- 通过命令⾏⽅式去激活不同环境的配置
To be continued...