Maven配置集profile

在开发场景中,通常有dev、sit和prod三个环境,分别对应开发、内部测试和生产。
在不同的环境中,因为数据、资源等隔离需要,往往需要不同的配置,这样在部署项目的时候就有着多套配置集灵活选择的需求(避免手动修改的繁琐操作)。
Maven中的profiles配置集就是很好的一个解决方案,需要那个配置就指定激活那个配置。

profile配置集

	<profiles>
		<!--基本配置-->
		<profile>
			<id>base</id> 
			<properties></properties>
			<activation>
				<!--默认激活此配置集-->
				<activeByDefault>true</activeByDefault>
			</activation>
			<build>
				<plugins>
					<plugin>
						<groupId>org.springframework.boot</groupId>
						<artifactId>spring-boot-maven-plugin</artifactId>
						<configuration>
							<systemPropertyVariables>
								<API_GW_xxx_SECRET_TOKEN>${apigw.com.secret.token}</API_GW_xxx_SECRET_TOKEN>
								<API_GW_yyy_SECRET_TOKEN>${apigw.cstk.secret.token}</API_GW_yyy_SECRET_TOKEN>
								<API_GW_zzz_SECRET_TOKEN>${apigw.dmgfe.secret.token}</API_GW_zzz_SECRET_TOKEN>
								<MY_DB_USERNAME>${dmg.db.username}</MY_DB_USERNAME>
								<MY_DB_PASSWORD>${dmg.db.password}</MY_DB_PASSWORD>
								<MY_DB_URL>${dmg.db.jdbc.url}</MY_DB_URL>
								<MY_DB_INITIAL_POOL_SIZE>${dmg.db.init.pool.size}</DMG_DB_INITIAL_POOL_SIZE>
								<MY_DB_MIN_POOL_SIZE>${dmg.db.min.pool.size}</MY_DB_MIN_POOL_SIZE>
								<MY_DB_MAX_POOL_SIZE>${dmg.db.max.pool.size}</MY_DB_MAX_POOL_SIZE>
								<KAFKA_HOST>${kafka.host}</KAFKA_HOST>
								<KAFKA_ORDER_STATUS_CHANGE_TOPIC>${kafka.topic.delivery-status-change}</KAFKA_ORDER_STATUS_CHANGE_TOPIC>
								<KAFKA_INTERNAL_TOPIC>${kafka.topic.delivery-status-change-internal}</KAFKA_INTERNAL_TOPIC>
								<LIS_FTP_USERNAME>${lis.ftp.username}</LIS_FTP_USERNAME>
								<LIS_FTP_PASSWORD>${lis.ftp.password}</LIS_FTP_PASSWORD>
								<LIS_FTP_HOST>${lis.ftp.host}</LIS_FTP_HOST>
								<LIS_FTP_HOME_DIR>${lis.ftp.home.dir}</LIS_FTP_HOME_DIR>
							</systemPropertyVariables>
						</configuration>
					</plugin>
				</plugins>
			</build>
		</profile>
		<!-- dev 环境 -->
		<profile>
			<id>dev</id>
			<properties>
				<java.options></java.options>
				<replica.count>1</replica.count>
				<route.name>echoo.dev.com</route.name>
				<spring.profiles.active>dev</spring.profiles.active>
				<namespace>test-dev</namespace>
			</properties>
			<build>
				<plugins>
					<plugin>
						<groupId>org.eclipse.jkube</groupId>
						<artifactId>openshift-maven-plugin</artifactId>
						<configuration>
							<access>
								<namespace>ruby-delivery-sit</namespace>
								<masterUrl>https://master.ocp.echoo.com:8443</masterUrl>
								<apiVersion>v1</apiVersion>
							</access>
							<resources>
								<replicas>1</replicas>
							</resources>
						</configuration>
					</plugin>
				</plugins>
			</build>
		</profile>
		<!-- sit 环境 -->
		<profile>
			<id>sit</id>
		</profile>
		<!-- prod环境 -->
		<profile>
			<id>prod</id>
		</profile>
	</profiles>

几个常用属性:

			<activation>
				<!--默认激活此配置集-->
				<activeByDefault>true</activeByDefault>
			</activation>

<activation>是激活属性,里面配置一些 profile 的激活相关的配置。
<activeByDefault>true</activeByDefault>是默认激活配置。true 表示这个 profile 默认是激活的,除非在命令行或其他地方明确指定了不激活它,相反 false 就表示默认不激活,除非指定激活。通常用来配置一些基本项。

			<build>
				<plugins>
					<plugin>
						<groupId>org.springframework.boot</groupId>
						<artifactId>spring-boot-maven-plugin</artifactId>
						<configuration>
							<systemPropertyVariables>
								<API_GW_xxx_SECRET_TOKEN>${apigw.com.secret.token}</API_GW_xxx_SECRET_TOKEN>
								<API_GW_yyy_SECRET_TOKEN>${apigw.cstk.secret.token}</API_GW_yyy_SECRET_TOKEN>
								<API_GW_zzz_SECRET_TOKEN>${apigw.dmgfe.secret.token}</API_GW_zzz_SECRET_TOKEN>
								<MY_DB_USERNAME>${dmg.db.username}</MY_DB_USERNAME>
								<MY_DB_PASSWORD>${dmg.db.password}</MY_DB_PASSWORD>
								<MY_DB_URL>${dmg.db.jdbc.url}</MY_DB_URL>
								<MY_DB_INITIAL_POOL_SIZE>${dmg.db.init.pool.size}</DMG_DB_INITIAL_POOL_SIZE>
								<MY_DB_MIN_POOL_SIZE>${dmg.db.min.pool.size}</MY_DB_MIN_POOL_SIZE>
								<MY_DB_MAX_POOL_SIZE>${dmg.db.max.pool.size}</MY_DB_MAX_POOL_SIZE>
								<KAFKA_HOST>${kafka.host}</KAFKA_HOST>
								<KAFKA_ORDER_STATUS_CHANGE_TOPIC>${kafka.topic.delivery-status-change}</KAFKA_ORDER_STATUS_CHANGE_TOPIC>
								<KAFKA_INTERNAL_TOPIC>${kafka.topic.delivery-status-change-internal}</KAFKA_INTERNAL_TOPIC>
								<LIS_FTP_USERNAME>${lis.ftp.username}</LIS_FTP_USERNAME>
								<LIS_FTP_PASSWORD>${lis.ftp.password}</LIS_FTP_PASSWORD>
								<LIS_FTP_HOST>${lis.ftp.host}</LIS_FTP_HOST>
								<LIS_FTP_HOME_DIR>${lis.ftp.home.dir}</LIS_FTP_HOME_DIR>
							</systemPropertyVariables>
						</configuration>
					</plugin>
				</plugins>
			</build>

<build>是项目构建属性,里面配置与项目构建相关的配置。
<plugins>是插件属性,里面配置插件。比如这里配置了一个spring-boot-maven-plugin,用来打包springboot项目。
<configuration>是插件的配置属性,与对应的插件绑定。
<systemPropertyVariables>是系统属性,这里自定义了很多系统属性,这些属性通常包含外部依赖的配置信息,如数据库连接、API 密钥、外部服务URL等。
这些属性在运行时可以通过 Java 的 System.getProperty() 方法访问,也可以在项目配置文件中以引用的方式${property-name}直接获取,比如:

spring:
  datasource:
    username: ${MY_DB_USERNAME}
    password: ${MY_DB_PASSWORD}
    url: ${MY_DB_URL}
    driver-class-name: oracle.jdbc.driver.OracleDriver
    type: oracle.ucp.jdbc.PoolDataSource
		<!-- dev 环境 -->
		<profile>
			<id>dev</id>
			<properties>
				<java.options></java.options>
				<replica.count>1</replica.count>
				<route.name>echoo.dev.com</route.name>
				<spring.profiles.active>dev</spring.profiles.active>
				<namespace>test-dev</namespace>
			</properties>
			<build>
				<plugins>
					<plugin>
						<groupId>org.eclipse.jkube</groupId>
						<artifactId>openshift-maven-plugin</artifactId>
						<configuration>
							<access>
								<namespace>ruby-delivery-sit</namespace>
								<masterUrl>https://master.ocp.echoo.com:8443</masterUrl>
								<apiVersion>v1</apiVersion>
							</access>
							<resources>
								<replicas>1</replicas>
							</resources>
						</configuration>
					</plugin>
				</plugins>
			</build>
		</profile>

<java.options></java.options>: Java选项属性,为了在将来的配置中设置JVM的启动选项。
<replica.count>1</replica.count>: 指定应用的副本数量为1。
<route.name>echoo.dev.com</route.name>: 定义路由名称(应用的访问URL)。
<spring.profiles.active>sit</spring.profiles.active>: 这告诉 Spring 框架要激活名为 sit 的Spring profile。
<namespace>ruby-delivery-sit</namespace>: 指定 OpenShift 中的命名空间(namespace),应用将在此命名空间中部署。
这里配置了一个 OpenShift 的 Maven 插件,用于

<configuration>: OpenShift 插件的配置部分。
<access>: OpenShift集群的访问配置。
<namespace>: 与上面提到的<properties>中的<namespace>相同,再次定义了OpenShift的命名空间。
<masterUrl>: OpenShift 集群的主URL,后续就通过这个URL把项目推上容器。
<apiVersion>: OpenShift API 的版本。
<resources>: OpenShift 资源配置。
<replicas>: 定义了应用的副本数量,与<properties>中的<replica.count>相对应。

配置参数来源

<MY_DB_USERNAME>${my.db.username}</MY_DB_USERNAME>

这里的${my.db.username}的真实值可以有多种来源:

  1. Maven 属性文件:
    Maven 的 settings.xml 文件中可以定义属性。
    pom.xml 文件的 <properties> 标签内,也可以定义属性。这些属性可以在整个 pom.xml 文件中通过 ${property-name}的形式引用。
  2. Maven 命令行参数:
    使用 -D 参数可以在 Maven 命令行中自定义属性。例如:
    mvn clean install -Dmy.db.username=your-value
  3. 外部属性文件:
    可以使用 maven-resources-plugin 或其他插件来从外部文件(如 .properties 文件)加载属性。这通常用于从版本控制系统中管理的文件中读取敏感信息,如数据库凭据。
  4. 等等…

mvn打包指定profile

mvn -DskipTests -P dev clean package

-P dev表示指定激活id为dev的配置集。
这样maven就会用dev的环境配置来构建项目。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Maven是一种流行的项目构建工具,通过使用Maven,我们可以定义和管理项目的依赖关系,并在构建过程中执行各种插件。 当我们使用Maven进行项目构建时,可以使用指定的profile来帮助我们完成特定的构建需求。Profile是一种Maven的特性,它允许我们定义一组配置元素,以根据特定的需求来激活或禁用某些构建步骤或插件。 若要使用指定的profile进行打包,则需要在项目的pom.xml文件中进行配置。首先,在pom.xml文件中添加一个新的profile元素,可以指定profile的id、activation条件以及任何其他的配置元素。 在配置profile时,我们可以使用activation元素来定义何时激活这个profile。例如,可以根据环境变量、操作系统等条件来激活特定的profile。 接下来,我们需要在pom.xml文件中指定要使用的profile。可以通过在命令行中使用“-P”参数来指定。例如,可以使用以下命令来指定profile为"dev": mvn clean package -P dev 通过上述命令,Maven将使用指定的profile来执行打包操作。这样,在构建过程中,只有与指定profile相关联的插件和配置元素会被执行。其他未被激活的profile将被忽略。 需要注意的是,除了命令行,profile还可以通过其他方式进行指定,例如在IDE中进行配置或在Maven配置文件中进行设置。 总之,通过使用Mavenprofile功能,我们可以根据特定需求来选择合适的profile,并通过指定命令行参数来进行打包操作,以达到定制化构建的目的。 ### 回答2: 要在Maven中打包指定的profile,可以通过使用以下命令行参数来实现: ```shell mvn clean package -P profile-name ``` 在上述命令中,`profile-name`是你想要打包的profile的名称。Maven将会加载并应用指定的profile配置,并使用该配置来打包项目。 在项目的`pom.xml`文件中,可以定义多个不同的profile,并根据不同的需求进行配置。每个profile都有一个唯一的名称,并且可以通过以下格式在`<profiles>`元素下进行定义: ```xml <profiles> <profile> <id>profile-name</id> ... <!-- 配置信息 --> ... </profile> </profiles> ``` 在定义的profile中,可以包含任意数量的配置信息,如依赖、插件、环境变量等。这些配置信息将在打包命令中根据所选择的profile生效。 当运行`mvn clean package -P profile-name`命令时,Maven将会加载并应用指定的profile配置,并自动应用相关的依赖和插件。最终,Maven将会根据配置完成项目的打包工作。 通过使用Mavenprofile功能,可以方便地根据不同的需求打包项目,提高开发和部署的灵活性。 ### 回答3: 要使用Maven打包指定Profile,首先需要在项目的pom.xml文件中配置Profile。在pom.xml文件中,可以使用<profiles>标签来定义不同的Profile。每个Profile可以有自己的id和相关配置。 首先,在pom.xml文件的<profiles>标签内,添加一个<profile>标签,设置Profile的id。比如,我们可以定义一个名为"prod"的Profile。在<profile>标签中,可以定义一些特定于该Profile的属性和配置。例如,可以设置不同的插件版本、依赖项、资源文件路径等。 然后,在<profiles>标签内的<profile>标签中,使用<activation>标签设置激活该Profile的条件。可以通过<activation>标签的条件设置来决定什么时候应该激活该Profile。比如,可以根据系统属性、环境变量、文件是否存在等条件来激活Profile。 接下来,在命令行中使用Maven命令来打包指定Profile。在命令行中,可以使用"-P"选项来激活特定的Profile。例如,使用以下命令来打包激活名为"prod"的Profile: mvn package -P prod 这样,Maven将会根据指定的Profile进行打包。它将使用<profiles>标签内所定义的相关配置、插件版本、依赖项等,从而生成特定的构建输出。 总结起来,要使用Maven打包指定Profile,我们需要在pom.xml文件中定义Profile并设置相关配置,然后在命令行中使用"-P"选项来激活指定的Profile。这样,Maven将会根据该Profile配置进行打包。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值