`
baobeituping
  • 浏览: 1071302 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Maven不同版本部署

 
阅读更多

上回继续,项目开发好以后,通常要在多个环境部署,象我们公司多达5种环境:本机环境(local)、(开发小组内自测的)开发环境(dev)、(提供给测试团队的)测试环境(test)、预发布环境(pre)、正式生产环境(prod),每种环境都有各自的配置参数,比如:数据库连接、远程调用的ws地址等等。如果每个环境build前手动修改这些参数,显然太不fashion.

maven早就考虑到了这些问题,看下面的pom片段:

复制代码
 1 <profiles>
 2         <profile>
 3             <!-- 本地环境 -->
 4             <id>local</id>
 5             <properties>                
 6                 <db-url>jdbc:oracle:thin:@localhost:1521:XE</db-url>
 7                 <db-username>***</db-username>
 8                 <db-password>***</db-password>
 9             </properties>
10         </profile>
11         <profile>
12             <!-- 开发环境 -->
13             <id>dev</id>
14             <properties>                
15                 <db-url>jdbc:oracle:thin:@172.21.129.51:1521:orcl</db-url>
16                 <db-username>***</db-username>
17                 <db-password>***</db-password>
18             </properties>
19             <!-- 默认激活本环境 -->
20             <activation>
21                 <activeByDefault>true</activeByDefault>
22             </activation>
23         </profile>
24         ...
25     </profiles>
复制代码

profiles节点中,定义了二种环境:local、dev(默认激活dev环境),可以在各自的环境中添加需要的property值,接下来修改build节点,参考下面的示例:

复制代码
 1 <build>
 2         <resources>
 3             <resource>
 4                 <directory>src/main/resources</directory>
 5                 <filtering>true</filtering>
 6             </resource>
 7         </resources>
 8         <plugins>
 9             <plugin>
10                 <groupId>org.apache.maven.plugins</groupId>
11                 <artifactId>maven-compiler-plugin</artifactId>
12                 <version>2.5.1</version>
13                 <configuration>
14                     <source>1.6</source>
15                     <target>1.6</target>
16                     <encoding>utf-8</encoding>
17                 </configuration>
18             </plugin>
19         </plugins>
20     </build>
复制代码

resource节点是关键,它表明了哪个目录下的配置文件(不管是xml配置文件,还是properties属性文件),需要根据profile环境来替换属性值。

通常配置文件放在resources目录下,build时该目录下的文件都自动会copy到class目录下

以上图为例,其中spring-database.xml的内容为:

复制代码
 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4     xsi:schemaLocation="http://www.springframework.org/schema/beans 
 5     http://www.springframework.org/schema/beans/spring-beans.xsd">
 6 
 7     <bean id="dataSource"
 8         class="org.springframework.jdbc.datasource.DriverManagerDataSource">
 9         <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
10         <property name="url" value="${db-url}" />
11         <property name="username" value="${db-username}" />
12         <property name="password" value="${db-password}" />        
13     </bean>
14 </beans>
复制代码

各属性节点的值,用占位符"${属性名}"占位,maven在package时,会根据profile的环境自动替换这些占位符为实际属性值。

默认情况下: 

maven package

将采用默认激活的profile环境来打包,也可以手动指定环境,比如:

maven package -P dev

将自动打包成dev环境的部署包(注:参数P为大写)

 

最后再给2个实例的运用例子:

1、开发环境与生产环境数据源采用不同方式的问题

本机开发时为了方便,很多开发人员喜欢直接用JDBC直接连接数据库,这样修改起来方便;

复制代码
 1     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
 2         destroy-method="close">
 3         <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
 4         <property name="url" value="${db-url}" />
 5         <property name="username" value="${db-username}" />
 6         <property name="password" value="${db-password}" />
 7         <property name="defaultAutoCommit" value="false" />
 8         <property name="initialSize" value="2" />
 9         <property name="maxActive" value="10" />
10         <property name="maxWait" value="60000" />
11     </bean>
复制代码

而生产环境,通常是在webserver(比如weblogic上)配置一个JNDI数据源,

1     <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
2         <property name="jndiName" value="appDS" />        
3     </bean>

如果每次发布生产前,都要手动修改,未免太原始,可以通过maven的profile来解决

先把配置文件改成 

复制代码
 1     <bean id="${db-source-jdbc}" class="org.apache.commons.dbcp.BasicDataSource"
 2         destroy-method="close">
 3         <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
 4         <property name="url" value="${db-url}" />
 5         <property name="username" value="${db-username}" />
 6         <property name="password" value="${db-password}" />
 7         <property name="defaultAutoCommit" value="false" />
 8         <property name="initialSize" value="2" />
 9         <property name="maxActive" value="10" />
10         <property name="maxWait" value="60000" />
11     </bean>
12     
13     <bean id="${db-source-jndi}" class="org.springframework.jndi.JndiObjectFactoryBean">
14         <property name="jndiName" value="appDS" />        
15     </bean>
复制代码

即用占位符来代替bean的id,然后在pom.xml里类似下面设置

复制代码
 1                <profile>
 2             <!-- 本机环境 -->
 3             <id>local</id>
 4             <properties>
 5                 ...
 6                 <db-source-jdbc>dataSource</db-source-jdbc>
 7                 <db-source-jndi>NONE</db-source-jndi>
 8                 <db-url>jdbc:oracle:thin:@172.21.129.51:1521:orcl</db-url>                
 9                 <db-username>mu_fsu</db-username>
10                 <db-password>mu_fsu</db-password>
11                 ...
12             </properties>
13             <!-- 默认激活本环境 -->
14             <activation>
15                 <activeByDefault>true</activeByDefault>
16             </activation>
17         </profile>        
18         <profile>
19             <!-- 生产环境 -->
20             <id>pro</id>
21             <properties>
22                 ...
23                 <db-source-jdbc>NONE</db-source-jdbc>
24                 <db-source-jndi>dataSource</db-source-jndi>
25                 ...
26             </properties>
27         </profile>
28     </profiles>
复制代码

这样,mvn clean package -P local打包本地开发环境时,将生成

 View Code

而打包生产环境 mvn clean package -P pro时,生成

 View Code

spring配置的其它跟数据库相关的bean,约定引用dataSource这个名称的bean即可

 

2、不同webserver环境,依赖jar包,是否打包的问题

weblogic上,允许多个app,把共用的jar包按约定打包成一个war文件,以library的方式部署,然后各应用在WEB-INF/weblogic.xml中,用类似下面的形式

复制代码
1 <?xml version="1.0" encoding="utf-8"?>
2 <weblogic-web-app xmlns="http://www.bea.com/ns/weblogic/90">
3     ...
4     <library-ref>
5         <library-name>my-share-lib</library-name>
6     </library-ref>
7 </weblogic-web-app>
复制代码

指定共享library 的名称即可。这样的好处是,即节省了服务器开销,而且各app打包时,就不必再重复打包这些jar文件,打包后的体积大大减少,上传起来会快很多。

而其它webserver上却未必有这个机制,一般为了方便,我们开发时,往往采用一些轻量级的webserver,比如:tomcat,jetty,jboss 之类,正式部署时才发布到weblogic下,这样带来的问题就是,本机打包时,要求这些依赖jar包,全打包到app的WEB-INF/lib下;而生产环境下,各应用的WEB-INF/lib下并不需要这些jar文件,同样还是用profile来搞定,先处理pom.xml,把依赖项改成类似下面的形式:

复制代码
1         <dependency>
2             <groupId>dom4j</groupId>
3             <artifactId>dom4j</artifactId>
4             <version>1.6.1</version>
5             <scope>${jar.scope}</scope>
6         </dependency>
复制代码

即scope这里,用一个占位符来代替,然后profile这样配置

复制代码
 1         <profile>
 2             <!-- 本机环境 -->
 3             <id>local</id>
 4             <properties>
 5                 <jar.scope>compile</jar.scope>
 6                 ...
 7             </properties>
 8             <!-- 默认激活本环境 -->
 9             <activation>
10                 <activeByDefault>true</activeByDefault>
11             </activation>
12         </profile>
13         <profile>
14             <!-- 生产环境 -->
15             <id>pro</id>
16             <properties>
17                 <jar.scope>provided</jar.scope>
18                 ...
19             </properties>
20         </profile>
复制代码

在maven里,如果一个依赖项的scope是provided,表示由容器提供,打包时将不会打包进最终的package里,所以这样配置后,生产环境打包时,依赖项的scope全变成了provided,即不打包进war文件,而本机环境下,因为scope是compile,所以会打包到war里

分享到:
评论

相关推荐

    maven快照版本和发布版本.docx

    与常规版本不同,Maven会持续检查远程仓库中是否有新的快照版本。例如,data-service团队可以发布data-service:1.0-SNAPSHOT来替换旧的快照jar包,每次更新时,版本号保持不变,但带有-SNAPSHOT后缀。 在Maven中,...

    maven项目跨机器部署

    myeclipse中maven的一些常见功能总结;借助maven将本地项目部署到远程tomcat容器。

    maven各版本

    本篇文章将深入探讨Maven的三个关键版本:3.0.4、3.2.5和3.3.9,这三个版本已被证实为稳定且功能完备的。 ### Maven 3.0.4 发布于2012年4月,Maven 3.0.4是3.x系列的一个早期版本,引入了若干改进和修复。主要亮点...

    jenkins实现maven项目自动部署到tomcat

    【Jenkins实现Maven项目自动部署到Tomcat】是一篇关于自动化构建和部署流程的教程。该文档旨在教你如何利用Jenkins自动化处理Maven项目的编译、打包和部署到Tomcat服务器的过程,使得开发工作更加高效。以下是详细的...

    maven3.0版本下载

    Maven是Java世界中的一款项目管理和综合工具,它通过提供一套标准化的构建过程,极大地简化了项目的构建、依赖管理和部署流程。Maven3.0版本是一个重要的里程碑,它引入了许多改进和新特性,使得开发人员在处理大型...

    ECLIPSE实现MAVEN项目自动部署NEXUS中

    ### Eclipse 实现 Maven 项目自动部署到 Nexus 在软件开发过程中,自动化构建和部署是非常重要的环节,能够极大地提高开发效率并减少人为错误。本篇文章主要介绍如何利用 Eclipse 和 Maven 将本地项目自动部署到 ...

    maven 多war部署

    【标题】:Maven多WAR部署详解 在Java Web开发中,Maven作为一个强大的构建工具,可以帮助我们管理和构建项目。当我们遇到需要在一个项目中包含多个独立的Web应用程序(WAR文件)时,Maven的多模块项目特性就显得尤...

    Maven安装部署.docx

    【Maven 安装部署】 Maven 是一个强大的项目管理工具,主要负责Java项目的构建、依赖管理和项目信息管理。它的核心理念是通过一个统一的项目对象模型(Project Object Model,POM),使得项目的构建过程标准化,...

    Maven自动升级版本号并打包上传的脚本

    4. Maven部署: 使用`maven-deploy-plugin`,我们可以将打包后的文件上传到远程仓库。通常,这需要配置`settings.xml`中的服务器ID、用户名和密码。命令`mvn deploy`会将文件上传到指定的远程仓库。 5. 自动化脚本...

    maven 3.3.9版本

    Maven 3.3.9是Apache Maven项目发布的一个稳定版本,它在Java开发社区中扮演着至关重要的角色。Maven是一个项目管理和综合工具,它通过使用一种标准化的构建过程,使得Java项目的构建、依赖管理和文档生成变得更加...

    maven 工程升级版本步骤

    ### Maven工程升级版本步骤 在软件开发过程中,随着项目的不断迭代和需求的变化,对Maven项目进行版本升级是一项常见的操作。下面将详细介绍如何通过一系列步骤完成Maven项目的版本升级。 #### 步骤一:更新Parent...

    apache-maven 最新版本

    尽管此处没有提供具体的版本信息,但一般来说,下载Apache Maven的最新版本意味着获取官方发布的稳定版本,以确保最佳的性能和兼容性。安装过程通常包括解压下载的文件、配置环境变量以及验证安装是否成功。 对于...

    maven 最新版本

    3. **生命周期(Lifecycle)**:Maven 的生命周期包含了一系列预定义的构建阶段,如编译(compile)、测试(test)、打包(package)、验证(verify)、安装(install)和部署(deploy)。 4. **插件(Plugins)**...

    Maven3.5~3.6.3各版本下载

    Maven的主要功能是帮助开发者快速构建、测试和部署项目。在实际项目开发中,Maven发挥着至关重要的作用。下面,我们将对Maven 3.5~3.6.3各版本的下载进行详细介绍。 Maven 3.5版本 Maven 3.5是Maven的稳定版,发布...

    最好用的maven3

    "最好用的maven3"这一标题表明了Maven 3版本因其高效和易用性而备受推崇。本文将深入探讨Maven 3的核心特性、安装配置、以及如何利用它进行项目的构建与管理。 ### 1. Maven 3 的核心特性 - **项目对象模型 ...

    maven3.3.9版本下载

    3. **生命周期 (Lifecycle)**:Maven 有一套预定义的生命周期,包括编译(compile)、测试(test)、打包(package)、验证(verify)、安装(install)和部署(deploy)等阶段。用户可以通过简单的命令行指令完成...

    apache-maven-3.3.9版本-稳定.rar

    此外,Maven还提供了一套丰富的插件系统,允许扩展其功能,例如,可以使用`maven-surefire-plugin`进行单元测试,`maven-assembly-plugin`创建自包含的部署包,或者`maven-site-plugin`生成项目站点和报告。...

    maven集成tomcat支持热部署

    本篇将详细介绍如何通过Maven集成Tomcat,实现项目的热部署,从而提高开发效率。 首先,集成Maven与Tomcat的核心在于Maven的插件管理。我们需要在项目的`pom.xml`文件中引入`maven-eclipse-plugin`和`maven-war-...

    apache-maven多版本.zip

    这个压缩包“apache-maven多版本.zip”包含了Maven的两个不同版本,即3.6.1和3.6.3,这使得用户可以在不同的项目或者环境下选择合适的版本进行使用。 **Maven简介** Maven是Apache软件基金会开发的一个项目管理和...

Global site tag (gtag.js) - Google Analytics