Spring可以使用Profile决定程序在不一样环境下执行状况,包含配置、加载Bean、依赖等。
Spring的Profile通常项目包含:dev(开发), test(单元测试), qa(集成测试), prod(生产环境)。由spring.profiles.active属性决定启用的profile。
SpringBoot的配置文件默认为 application.properties(或yaml,此外仅以properties配置为说明)。不一样Profile下的配置文件由application-{profile}.properties管理,同时独立的 Profile配置文件会覆盖默认文件下的属性。web
Maven一样也有Profile设置,可在构建过程当中针对不一样的Profile环境执行不一样的操做,包含配置、依赖、行为等。
Maven的Profile由 pom.xml 的<Profiles>标签管理。每一个Profile中可设置:id(惟一标识), properties(配置属性), activation(自动触发的逻辑条件), dependencies(依赖)等。
此文章不对Spring和Maven的Profile做过多说明,详细状况请自行查阅。spring
因为构建是基于Maven(或Gradle,此处仅以Maven说明)。因此使用Maven管理Spring构建时的Profile是很是方便的。
Maven管理Spring Profile分五步,如下详细介绍。apache
在SpringBoot MVC项目中,默认之内嵌Tomcat运行,若是须要特殊的设置或者使用Undertow,须要去掉默认的Tomcat依赖:tomcat
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency>
若是你同时使用了 MyBatis,须要去掉tomcat-jdbc依赖:bash
<dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <exclusions> <exclusion> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-jdbc</artifactId> </exclusion> </exclusions> </dependency>
在项目(若是有模块为具体模块)的pom.xml下设置:mybatis
<!-- Maven控制Spring Profile --> <profiles> <profile> <id>dev</id> <activation> <activeByDefault>true</activeByDefault> </activation> <properties> <profileActive>dev</profileActive> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </dependency> <dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-jdbc</artifactId> </dependency> </dependencies> </profile> <profile> <id>prod</id> <properties> <profileActive>prod</profileActive> </properties> </profile> </profiles>
从上面的配置能够看出,Maven的Profile配置了两个:dev和prod,而且在dev中使用了内嵌Tomcat,而 prod 中没有,因此这两个Profile打包的文件dev能够直接运行(Plugin使用了SpringBoot Plugin),而prod并不能直接运行(或部署在外部Tomcat下,并不推荐这样,后面会说明)。
properties中的profileActive是咱们申明的属性,此处对应Spring的Profile值。app
SpringBoot的 Profile选择须要在 application.properties中配置,若是定死在文件,那么每次打包都须要手动修改,很麻烦,并且容易出错。
Maven的资源过滤功能能够实如今构建时修改以“@xxx@”表示的属性。资源过滤须要在pom.xml的<build>标签下配置 resources:maven
<!-- profile对资源的操做 --> <resources> <resource> <directory>src/main/resources</directory> <excludes> <exclude>application*.properties</exclude> </excludes> </resource> <resource> <directory>src/main/resources</directory> <!-- 是否替换@xx@表示的maven properties属性值 --> <filtering>true</filtering> <includes> <include>application.properties</include> <include>application-${profileActive}.properties</include> </includes> </resource> </resources>
上面的第一个resource去掉了src/main/resources下的全部application*.properties文件,“*”是通配符,表示此处有任何内容(没有也能够)都匹配。
第二个resource添加了application.properties默认配置文件和由profileActive属性决定的相应profile配置文件。而且filtering为true表示,会将文件内容的“@xx@”替换为相应的变量(如文件中的@profileActive@会替换为profileActive属性值)。spring-boot
在application.properties默认配置文件中配置:单元测试
spring.profiles.active = @profileActive@
@profileActive@表示该属性值会在maven构建时被替换掉。
构建命令:
mvn clean package -Pdev
上面的命令会根据Maven Profile的 dev构建环境包,若是须要prod包,则把-P的参数替换成prod便可。
为了方便我会在每一个项目下生成一个build.sh文件,内容以下:
#!/bin/bash profileActive=prod if [ -n "$1" ]; then profileActive=$1 fi mvn clean package -Dmaven.test.skip=true -P$profileActive
该脚本接收一个参数,即打包对应的Profile。默认状况下若是不带参数,会打包prod环境包。
须要注意的是,该命令跳过了测试。
完成了上面的五步,便可使项目根据你的构建参数的不一样,打包出不一样环境下运行的包。