百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Maven中profile和filtering实现多个环境下的属性过滤

yuyutoo 2025-01-01 23:23 4 浏览 0 评论

背景

项目构建的时候,需要根据不同的场景来改变项目中的属性资源,最为常见的莫过于数据库连接配置了,试想有生产环境、测试缓存、发布环境等,需要为不同的场景下来动态的改变数据库的连接配置。而使用maven就可以帮我们解决这些问题。下面就来分享一下maven中的profile和filtering的属性。

为了便于测试一下功能,需要搭建maven的web项目,具体配置请详见如何用maven创建web项目

filtering功能

主要用来替换项目中的资源文件(*.xml、*.properties)当中的${...},比如${db.url},那么如果配置了db.url=aaa的话,在项目编译的时候,就会自动地把${db.url}替换为aaa,下面以实例来讲解一下

采取参照博客中创建完maven的web项目后,会看到src/main/sources的目录,在此目录下面创建个“test.properties”,里面随便来上一行,例如Hello ${user.name},好了,接下来修改我们的pom文件,来启动filtering功能

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>

<groupId>testwebProject</groupId>

<artifactId>com.test.web.test</artifactId>

<version>0.0.1-SNAPSHOT</version>

<packaging>war</packaging>

<build>

<!--第一种方式,两种方式都需要指定需要编译的目录 -->

<resources>

<resource>

<directory>src/main/resources</directory>

<!--可以在此配置过滤文件 -->

<includes>

<include>**/*.xsd</include>

<include>**/*.properties</include>

</includes>

<!--开启filtering功能 -->

<filtering>true</filtering>

</resource>

</resources>

<plugins>

<plugin>

<artifactId>maven-war-plugin</artifactId>

<configuration>

<version>2.5</version>

</configuration>

</plugin>

</plugins>

</build>

</project>

然后编译我们的maven项目

mvn clean compile -Duser.name=tom

编译完后,查看输出文件 target/classes/test.properties 的内容,可见原先的 “Hello {user.name}” 已经变成 “Hello Tom”。

上面如果麻烦的话,也可以把filtering用到的变量写在项目的属性段里面,如下面的方式

<!--也可以配置到外部属性里面 -->
<properties>

<user.name>Lucky</user.name>

<user.age>50</user.age>

</properties>

进行编译,mvn clean compile,在此查看的话,就会看到属性被替换的效果

当然了,如果属性比较多的话,那么此时可以把属性单独抽取出来一个*.properties文件来保存,例如我们在pom.xml的同级目录下面创建一个project.properties,里面指明我们的内容

user.name=Lucky

紧接着在修改我们的pom文件,如下

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>

<groupId>testwebProject</groupId>

<artifactId>com.test.web.test</artifactId>

<version>0.0.1-SNAPSHOT</version>

<packaging>war</packaging>

<build>

<!--第一种方式,两种方式都需要指定需要编译的目录 -->

<resources>

<resource>

<directory>src/main/resources</directory>

<!--可以在此配置过滤文件 -->

<includes>

<include>**/*.xsd</include>

<include>**/*.properties</include>

</includes>

<!--开启filtering功能 -->

<filtering>true</filtering>

</resource>

</resources>

<filters>

<!-- 是以该pom文件路径作为参考 -->

<filter>project.properties</filter>

</filters>

<plugins>

<plugin>

<artifactId>maven-war-plugin</artifactId>

<configuration>

<version>2.5</version>

</configuration>

</plugin>

</plugins>

</build>

</project>

再次执行编译命令的话,就会看到效果

profile功能

允许在项目文件(pom.xml)里面定义若干个profile段,然后在编译时选择其中的一个用于覆盖项目文件原先的定义。接着上一个例子,如果我们需要为开发环境和生产环境定义不同的 user.name 属性值,则我们在项目目录里创建两个属性文件分别是pre.properties和dev.properties,然后在每个文件里分别写入user.name=lucky和user.name=wangwang,然后在此修改我们的pom文件,修改后如下所示

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>

<groupId>testwebProject</groupId>

<artifactId>com.test.web.test</artifactId>

<version>0.0.1-SNAPSHOT</version>

<packaging>war</packaging>

<build>

<!--第一种方式,两种方式都需要指定需要编译的目录 -->

<resources>

<resource>

<directory>src/main/resources</directory>

<!--可以在此配置过滤文件 -->

<includes>

<include>**/*.xsd</include>

<include>**/*.properties</include>

</includes>

<!--开启filtering功能 -->

<filtering>true</filtering>

</resource>

</resources>

<profiles>

<profile>

<id>dev</id>

<activation>

<!--默认的编译选项 -->

<activeByDefault>true</activeByDefault>

</activation>

<build>

<filters>

<filter>pre.properties</filter>

</filters>

</build>

</profile>

<profile>

<id>pre</id>

<build>

<filters>

<filter>dev.properties</filter>

</filters>

</build>

</profile>

</profiles>

<plugins>

<plugin>

  <artifactId>maven-war-plugin</artifactId>

  <configuration>

  <version>2.5</version>

  </configuration>

</plugin>

</plugins>

</build>

</project>

在编译项目时,可以使用 -P 参数指定需要使用的 profile 的 id,比如下面命令将会使用 dev profile:

mvn clean compile -Pdev

如果想使用pre,只需要改为以下即可

mvn clean compile -Ppre

假如不指定 -P 参数的话,则会使用 activeByDefault=true 的一项(即 pre)。

相关推荐

MySQL中的数据类型(mysql数据类型有哪些,并举例)

MySQL中的数据类型...

mysql窗口函数over中rows_MySQL窗口函数

下面的讲解将基于这个employee2表:mysql>SELECT*FROMemployee2;+----+-----------+------+---------+---------...

别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究

总想写一篇MySQL的设计和列类型选取的文章,一直挤不出时间。天天晚上都要加班,正逢5.1放假,抽了几天就有了此文。如果对朋友们能有帮助的话,关注一波不过分吧?求关!选择更优的数据类型尽量选择存储空间...

MySQL数据库知识(mysql数据库相关知识)

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

MySQL实战——表结构设计之数字类型

整型不建议刻意去用unsigned属性,因为在做一些数据分析时,SQL可能返回的结果并不是想要得到的结果。比如在财务的场景下,经常会做一些加减操作。MySQL要求unsigned数值相减之...

MySQL数据库入门(四)数据类型简介

在MySQL中数据类型有以下五种:数字整数:常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyintunsigned,用来表示年龄(值范围是0-...

mysql常用语句超级详细汇总(mysql常用语法)

1.连接数据库:连接本地数据库:mysql-uroot-p连接远程数据库:mysql-h192.169.22.199-uroot-p退出数据库:exit...

MYSQL——CAST()函数的用法(mysql中case)

语法为:Cast(字段名as转换的类型),其中类型可以为:CHAR[(N)]字符型DATE日期型DATETIME日期和时间型...

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择引言部分你是否遇到过这样的情况:明明已经按照最佳实践选择了MySQL的InnoDB引擎,却发现某些查询依然缓慢得令人沮丧?或者当你的...

MySQL 表分区?涨知识了(mysql数据表分区)

1.什么是表分区...

《MySQL必知必会》_笔记08(mysql必知必会mobi)

第19章插入数据一、数据插入概述INSERT语句用于向数据库表中插入(添加)数据,是SQL中常用的数据操作语句之一。它可以用多种方式使用,包括插入完整的行、插入行的一部分、插入多行以及插入某些查询的...

当 SQL Server(mssql-jdbc) 遇上 BigDecimal → 精度丢失,真坑!

开心一刻  中午和哥们一起喝茶  哥们说道:晚上喝酒去啊...

MYSQL有哪些数据类型(mysql有哪些数据类型,有哪些运算符)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

使用MySQL分区的注意事项(使用mysql分区的注意事项有哪些)

MySQL分区是将一个表分解成多个区块进行操作和保存,从而降低每次操作的数据量,提高性能。从逻辑上看,只有一个表,但物理上这个表可能由多个物理分区组成,每个分区都是一个独立的对象,可以进行独立处理。...

取消回复欢迎 发表评论: