maven学习笔记(四)profile的使用
目录
背景
配置
生产中的使用
.properties读取pom中变量
背景
在开发过程中,我们的项目会存在不同的运行环境,比如开发环境、测试环境、生产环境,而我们的项目在不同的环境中,有的配置可能会不一样,比如数据源配置、日志文件配置、以及一些软件运行过程中的基本配置,那每次我们将软件部署到不同的环境时,都需要修改相应的配置文件,这样来回修改,很容易出错,而且浪费劳动力。而maven的profile机制可以很好的解决上述问题。
配置
先来看一组profile配置
<profiles><profile><id>test</id><properties><revision>${snapshot_version}</revision></properties></profile><profile><id>prod</id><properties><revision>${release_version}</revision></properties><activation><activeByDefault>true</activeByDefault></activation></profile></profiles>上面子节点的具体含义
id:profile的唯一标识,可用于命令行激活,如,mvn pacakge -Pmyid,即打包时指定使用id为myid的profile
activation:激活器,定义了自动触发此profile的条件逻辑
properties:自定义的可以在整个POM中作为替换使用的字段,如果启用,通常用作过滤器。格式是<name>value</name>
只介绍这三个,再对activation的子节点介绍一下:
activeByDefault:设为true,此profile将默认被激活,除非另一个profile激活通过命令行-P的方式或被其激活器激活
生产中的使用
在生产环境中,经常会遇到微服务各个模块升级版本以及不同环境打snapshot/release jar包的问题,那么是如何解决以上两类问题的呢
- 子模块升级版本保持版本统一
项目中的目录结构如上图所示
父pom
可以看到父pom是通过${}的方式,找到了profile文件中revision所需依赖的版本,所依赖的版本再找到<properties>标签中具体的指向。
consumer子pom中的继承
<parent><artifactId>crm-user-service</artifactId><groupId>com.ziroom.crm</groupId><version>${revision}</version></parent>provider中子pom的继承
<parent><artifactId>crm-user-service</artifactId><groupId>com.ziroom.crm</groupId><version>${revision}</version></parent>provider中对consumer实体的依赖
<dependency><groupId>com.ziroom.crm</groupId><artifactId>crm-user-service-consumer</artifactId><version>${project.version}</version></dependency>可以看到遵循了这样一种方式
由此就可以实现,父pom中改动一处版本,子模块跟着升级
<properties> <snapshot_version>1.7.2-SNAPSHOT</snapshot_version><release_version>1.7.2</release_version></properties>- 区分环境
maven支持 mvn compile -Ptest的方式进行指定profile环境的编译,但是到了生产环境是如何编译的呢,我们公司采用的是omega平台集成了maven命令
测试环境
生产环境
根据以上的配置就可以在不同环境做区分。
项目现在的配置是发布后自动打出jar包,所以只需要在测试环境指定
<snapshot_version>xxxxxx-SNAPSHOT</snapshot_version>在生产环境指定
<release_version>xxxxx</release_version>就可以分别生成snapshot/release版本的jar包,并根据后缀名分别上传到不同的仓库。
.properties读取pom中变量
想要在.properties完成下面的效果,
先要引入maven-resources-plugin插件
<plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-resources-plugin</artifactId><version>2.7</version><configuration><!-- 在构建路径中 指定源文件编译的字符编码 --><encoding>UTF-8</encoding></configuration></plugin> </plugins>上述插件的作用是替换掉.properties中的占位符,详细功能请参考maven-maven-resources-plugin插件使用 - 意犹未尽 - 博客园
配合profiles文件使用时,则在确定具体环境后,会从pom文件中找到<properties>标签,再找到对应的<env.name>标签替换掉.properties中的${env.name}。
pom文件 <profiles><profile><id>env.dev</id><activation><activeByDefault>true</activeByDefault></activation><properties><env.name>dev</env.name><log.console><appender-ref ref="CONSOLE"/></log.console></properties></profile><profile><id>env.test</id><properties><env.name>test</env.name></properties></profile></profiles>总结
以上是生活随笔为你收集整理的maven学习笔记(四)profile的使用的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 解决vscode下载速度太慢的问题
- 下一篇: 如何查看手机绑定过的网站或者APP:注销