maven (profiles)装载不同环境所需的配置文件

引子:

  maven与java的联系在今天的项目已经是不可分割的 ,但是不同的项目有各具特色的项目结构,不同的项目结构使用了不同的maven插件,想要了解一个项目的项目结构,或者自己构建一个具有成熟结构体系的项目,那么,了解到熟悉的使用maven插件那么就是势在必行的了。

maven装载不同环境所需的配置文件

  场景:

  企业及应用,摆脱不了三个环境,研发环境,测试环境,生产环境,或者灰度环境,甚至更多。不同的环境 有不同的配置,那么如何在项目发布打包时将所需的配置正确的装载呢。

正常情况下,这些不同环境的配置放在了相似的配置文件,或者类似的包结构下。

  我们会使用以下命令,来装载不同的配置文件:

mvn clean package -P uat

  以上的配置代表了我们将选择prod下包括的相关配置文件,这依赖于pom的相关profile配置 ,实际上profile文件是由maven conf/setting.xml而来的,但这里配置的是全局变量,对于一个开发者我们往往在具体的项目里配置相关的profile,以方便在打包时选择。

示例配置如下:



    <profiles>
        <profile>
            <id>dev</id>    <!-- a. _P后的参数-->
            <activation>
                <activeByDefault>true</activeByDefault>   <!-- b.    表示是否默认激活  mvn clean package 加载的就是此配置下的文件-->
            </activation>
            <properties>
                <finalName.suffix>dev</finalName.suffix><!-- c.  最终项目包后缀-->
                <sysconfig.properties.file>sysconfig-dev.properties</sysconfig.properties.file> <!-- d. 选择加载的配置,注意这并不代表打包时就使用这个配置文件了,而是声明sysconfig.properties.file这个变量留待其他地方调用-->
                <ucmp.log.home>d:/app/applogs/ucmp</ucmp.log.home>  <!-- 同样是声明变量,而不是指定文件-->
            </properties>
        </profile>
        <profile>
            <id>uat</id>
            <properties>
                <finalName.suffix>uat</finalName.suffix>
                <sysconfig.properties.file>sysconfig-uat.properties</sysconfig.properties.file>
                <ucmp.log.home>/app/applogs/ucmp</ucmp.log.home>
            </properties>
        </profile>

  需要留意的是,properties 。下的文件都是变量的声明,而不是变量的使用都是需要其他地方调用的 ,正如 properties 代表的是属性。

  关于我们声明的这三个属性我们分别在这三个地方指定加载,

<build>
        <finalName>${project.artifactId}-${finalName.suffix}-${project.version}</finalName>
<!-- 环境配置和war包分离 以外部配置为准 -->
<context:property-placeholder order="1"
   ignore-resource-not-found="true" ignore-unresolvable="true"
   location="file:${CONF_PATH}/${sysconfig.properties.file}" />

<context:property-placeholder
   order="2"
   ignore-resource-not-found="true"
   ignore-unresolvable="false"
   location="classpath*:/${sysconfig.properties.file}" />  
    <property name="instance_name" value="${jboss.server.name:-default}" />
    <property name="log_home" value="${ucmp.log.home}/${instance_name}" />
    <property name="logfile_maxsize" value="100MB" />

最终打包后的结果如下

uat替换${finalName.suffix}  ,sysconfig-uat.properties替换${sysconfig.properties.file}

那是否这样就代表万事大吉了,答案是否定的 ,这样的我们会发现在打包时上述声明的几个配置文件都有打入jar包只是在spring配置阶段加载了我们声明的 ,这样的包是不够简洁的。

同时在复杂的环境中我们将所有的配置变量都放入一个配置文件也是行不通的,这样会大大降低代码的可读性。

 
时间: 2024-11-06 21:38:46

maven (profiles)装载不同环境所需的配置文件的相关文章

利用maven-assembly-plugin加载不同环境所需的配置文件

背景: 如何加载不同环境的配置文件已经成了实在必行的,我们通常利用profile进行,详情参见我上篇博客 http://www.cnblogs.com/lianshan/p/7347890.html,但是单单的profile实在无法满足我们的需求,我们将它与maven-assembly-plugin,结合起来,来实现配置分离的问题. profile不同环境参数设置 此参数的配置与上篇几乎相同,不过是在properties的属性声明将其与assembly结合起来,具体示例如下. <profiles

Eclipse Maven profiles 多环境配置,测试环境与开发环境分开打包

1.将开发环境.测试环境.生产环境的配置文件分开存放,如下图: 2.在Maven中配置不同的环境打包配置文件的路径,配置如下: <profiles> <profile> <!-- 开发环境 --> <id>dev</id> <properties> <env>dev</env> </properties> <activation> <!-- 默认激活该profile节点-->

【转】maven profile实现多环境打包

作为一名程序员,在开发的过程中,经常需要面对不同的运行环境(开发环境.测试环境.生产环境.内网环境.外网环境等等),在不同的环境中,相关的配置一般不一样,比如数据源配置.日志文件配置.以及一些软件运行过程中的基本配置.每次在不同环境部署程序时,都需要修改相应的配置文件,使之完成环境的配置.这么做存在一个比较大的问题:每次修改配置非常麻烦,而且配置错误会产生不可预估的影响,比如,在发布生产环境时用的开发环境的配置还好,但如果在开发环境下用生产环境的数据,将会造成生产数据的污染,导致生产环境崩溃.

maven profile实现多环境配置

每次项目部署上线都需要手动去修改配置文件(比如数据库配置,或者一个自定义的配置)然后才能打包,很麻烦,网上找到 maven profile可以完成这个工作,记录如下: 环境:eclipse + spring mvc + maven 1.直接看图,把数据库的配置单独拿出来放在了resources_env目录下,三个不同环境参数不同, 2,在pom文件中添加配置    这个引用自:http://www.cnblogs.com/raphael5200/p/6677549.html,感谢 <profil

使用maven profile实现多环境可移植构建

在开发过程中,我们的软件会面对不同的执行环境.比方开发环境.測试环境.生产环境,而我们的软件在不同的环境中.有的配置可能会不一样.比方数据源配置.日志文件配置.以及一些软件执行过程中的基本配置,那每次我们将软件部署到不同的环境时,都须要改动对应的配置文件.这样来回改动,是个很麻烦的事情.有没有一种方法可以让我们不用改动配置就能公布到不同的环境中呢?当然有.这就是接下来要做的事. 当然,这里的前提是使用maven做为构建工具. 使用maven来实现多环境的构建可移植性.须要借助maven提供的pr

Maven项目下HttpServletRequest 或 HttpServletResponse需引用的依赖包

转载: http://xyly624.blog.51cto.com/842520/865630/ Maven项目下HttpServletRequest 或 HttpServletResponse需引用的依赖包:servlet-api.jar,并将scope设置为provided. pom.xml: <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifac

Maven构建Hadoop开发环境

Maven构建Hadoop开发环境 软件环境:Eclipse Kepler x64 & Hadoop 1.2.1 & Maven 3 硬件环境:Centos 6.5 x64 1.Maven创建项目 使用CMD命令在工作空间执行 E:\ws\mvn archetype:generate -DarchetypeGroupId=org.apache.maven.archetypes -DgroupId=org.conan.myhadoop.mr -DartifactId=myHadoop -Dp

【甘道夫】Eclipse+Maven搭建HBase开发环境及HBaseDAO代码示例

环境: Win764bit Eclipse Version: Kepler Service Release 1 java version "1.7.0_40" 第一步:Eclipse中新建Maven项目,编辑pom.xml并更新下载jar包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance&qu

jenkins+gitlab+maven+tomcat持续集成环境安装配置

jenkins+gitlab+maven+tomcat,该环境主要实现自动构建部署java web应用. 其工作流程是:提交代码到gitlab--jenkins触发构建任务--maven编译打包--jenkins将war包部署到tomcat. 安装JDK #安装jdk1.8 tar zxvf jdk-8u77-linux-x64.gz #设置环境变量 #vi /etc/profile export JAVA_HOME=/usr/local/jdk1.8.0_77 export JAVA_BIN=