【SpringBoot专题】多环境配置及swagger

前言

在上一篇博客《【SpringBoot专题】快速体验 》中已经带领大家初步了解了SpringBoot,本篇博客将为大家介绍多环境配置、swagger等相关内容。


多环境配置分析

在实际开发中,我们可能会涉及到一些环境,比如local(本地开发环境),dev(部署到远程的开发环境),test(预发布环境),product(生产环境)。显然,不同的环境下,对应不同的配置信息,比如db/redis/mq等,甚至不同的环境下,程序需要做不同的处理。那么springboot项目是如何支持多环境配置的呢?

首先来说,springboot就是一个可执行程序,通过java -jar的方式启动的,那么我们需要在启动的时候,告诉springboot当前的profile(环境)是什么,即:

java -jar xxx.jar --spring.profiles.active=test

通过这个--spring.profiles.active=test就是在告诉springboot,我们设置的profile是test。

实际开发中常用的多环境配置方式

多环境配置

如果你设置了--spring.profiles.active=test,那么springboot会支持加载application-test.properties文件。如果我们通过分目录来存放不同环境的配置文件呢,那么这个时候,需要我们先获取profile。

获取当前profile的方式

从入口类获取profile

java -jar xxx.jar --spring.profiles.active=test

说白了,字符串“--spring.profiles.active=test”会传递到入口类的main方法的String[] args中!

CommandUtils

how to get profile from args

我们从args进行遍历处理,如果找到profile,那么通过System.setProperty进行系统key/value的设置(这里的key为"profile"),这是为了保存profile,方便以后拿到。

注意到,如果不给profile,那么自动设置为dev。

看一下CommandUtils中具体的解析profile方法

parseSpringProfile
定义的Env枚举类型

到这里,我们就可以根据profile来加载该profile下的配置文件了,比如:

引用系统设置的profile变量

在上文中,我们已经System.setProperty进行设置,将当前环境信息设置到profile变量中,因此我们直接进行${profile}引用了。

我们来看看application.properties文件内容:

根据不同的profile设置不同的启动端口

假设我们想以test环境部署应用:

profile=test
port=7072

验证:

是否可以取得profile,是否可以加载特定目录下的属性文件
不同环境目录下的配置文件

结果:

获取profile验证
得到了test环境下的mongo配置

好了,到这里,多环境的配置就给大家介绍完毕了~


swagger

Swagger,英文翻译过来,就是有点拽,酷的意思,名符其实!

Swagger同springboot集成很简单,是一个很强大的api框架,不仅提供了在线文档的查阅(好似java doc),还提供了在线的http测试(好似postman等),简单帅气~

如何集成呢?

还有 30% 的精彩内容
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
支付 ¥2.99 继续阅读

推荐阅读更多精彩内容