`
snoopy7713
  • 浏览: 1149645 次
  • 性别: Icon_minigender_2
  • 来自: 火星郊区
博客专栏
Group-logo
OSGi
浏览量:0
社区版块
存档分类
最新评论

svn和maven结合使用

阅读更多

目前项目组在开发一个项目,由多个子模块构成,构建工具是maven,版本控制工具是svn。本文想对如何结合使用maven和svn提出一点初步的想法

一、只有svn的情况

首先考虑没有maven的情况。这样的话,项目组每个开发人员,都需要在本地check out所有的源码。

每次提交之前,需要先更新周边工程的代码。由于工程之间是依赖的,所以很可能需要把所有的代码都更新一遍。在项目依赖混乱的情况下,就更麻烦

等于说,项目组成员之间的协作,是以SVN为中心的

这种做法的缺点在于:

    1、开发人员本地需要有所有的代码,编译速度很慢

    2、如果是别人负责的模块出错,会影响自己的开发。如果项目比较大的话,别人负责的模块的问题,自己实际上是解决不了的

这种做法的优点在于:

    1、提交之前做一次全量更新,相当于在本地做了一次全量编译,提交到SVN上基本可以保证不会出现编译错误。我称之为“悲观提交”,类似于数据库里“悲观锁”

    2、由于本地有所有代码,所以本地构建比较不容易出错

二、引入maven的情况

maven的主要作用之一,就是对模块化开发的支持

开发人员A机器上可以只有工程A,开发人员B机器上只有工程B,其中工程B依赖工程A

只要工程A已经deploy到了远程仓库(私服),那么工程B就可以在本地构建,不需要有工程A的代码。也就是说,每个开发人员本地,都只需要check out自己负责的工程

这种做法的优点在于:

    1、每个人只有自己负责的代码,本地构建的速度快

    2、如果其他的模块构建出错,对自己的模块不容易造成影响

    3、职责划分清晰

这种做法的缺点是:

    1、高层模块的构建,依赖于低层的模块。由于开发人员B本地只有工程B的代码,如果工程A还没有deploy到远程仓库,则工程B就无法进行本地构建

    2、提交到SVN后,有可能造成SVN上的全量编译失败。比如A删除了一个方法,并提交到svn,但是没有deploy。那么B就会基于A模块旧的构件来进行本地构建,成功后也提交了代码。这样的话,在svn上编译就无法通过

要避免发生以上的问题,我觉得在项目组内要遵循2个规定:

    1、提交了代码,需要同时将模块deploy进远程仓库。以免造成远程仓库的构件与svn源代码的不一致

    2、需要在pom里将构件更新的策略设置为always

Xml代码  收藏代码
  1. < snapshots >   
  2.                 < enabled > true </ enabled >   
  3.                 < updatePolicy > always </ updatePolicy >   
  4.             </ snapshots >   


以上2个规定,第一个是解决提交不一致的问题,第二个是解决获取不一致的问题。目的都是为了避免构建成功,但是svn上全量编译失败的问题

由于是先提交,再发现是否SVN编译失败,所以我称之为“乐观提交”

三、比较

总的来说,上述两种方式的区别,关键在于:一种是本地有所有的代码;另一种是本地只有自己负责的代码

对于小项目来说,不存在这个问题。但是如果是比较大的项目,我认为后者是更优的,但是会引入一些额外的问题,需要项目组所有人遵循规范来避免

四、引入CI

结合使用svn和maven,如果引入CI的话,可以让这个过程更加容易

开发人员在本地构建成功之后,把代码提交到svn,由CI系统(比如hudson),来完成deploy的动作

或者,使用SCM插件,绑定到deploy阶段。在deploy成功之后,由插件完成提交svn的动作。这样也可以保证提交svn和deploy的一致性

如果提交之后,在svn上全量编译失败,那么CI系统也会第一时间通知相关人员

五、总结

总的来说,我认为有以下几点:

1、建议采用分模块开发的方式,每个开发人员仅check out自己负责的代码

2、将snapshots更新策略设置为always

3、用ci系统或者scm插件,保证check in和deploy的一致性

4、依赖ci系统,来及时发现svn上的编译错误

分享到:
评论

相关推荐

    eclipse svn-maven插件

    4. **Eclipse SVN Maven插件**:此插件将Eclipse、SVN和Maven的功能结合在一起,使开发者能够在Eclipse环境中无缝地进行版本控制和项目构建。安装该插件后,用户可以直接在IDE内执行SVN的add、commit、update、merge...

    svn+maven+shell自动发布代码

    本文将详细阐述如何结合Subversion (SVN)、Maven和Shell脚本来实现代码的自动发布。 **Subversion (SVN)** 是一个版本控制系统,用于跟踪和管理项目源代码的变化。在自动部署的场景中,SVN主要用于存储和更新项目...

    svn-maven-andrion插件

    ADT与Maven和svn结合,可以帮助开发者更有效地管理Android项目的构建和版本控制。 4. **集成工作流程**: "svn-maven-andrion插件"将这三个关键组件整合到一起,使得开发者可以在一个统一的环境中进行所有操作。...

    Jenkins+Svn+Maven培训

    Jenkins+Svn+Maven培训的知识点主要围绕持续集成(Continuous Integration,简称CI)的概念、原则、实践以及Jenkins、SVN和Maven三款工具的具体使用方法。 首先,持续集成(CI)是一种软件开发实践,旨在促进开发...

    手把手图解,详解Jenkins ,svn ,maven 项目持续集成 SHELL 脚本

    "手把手图解,详解Jenkins,svn,maven项目持续集成SHELL脚本"这个标题表明了本文将通过图形化的解释,详细介绍如何使用Jenkins、Subversion(svn)和Maven这三个工具来实现软件项目的持续集成,并涉及到使用SHELL脚...

    Eclipse Maven插件,SVN插件

    在实际开发中,Eclipse Maven插件和SVN插件的结合使用对于Java开发者来说非常有益。m2e可以帮助管理项目依赖,构建和打包应用,而SVN插件则确保了团队成员之间的代码同步和历史追踪。这两个工具的集成,使得Eclipse...

    Svn Git Maven版本管理教程

    - **项目对象模型(POM)**: Maven使用一个XML文件(pom.xml)作为配置文件,定义项目的结构和依赖关系。 - **生命周期**: Maven定义了多个项目构建周期,如clean、default、site等。 - **构建阶段**: 每个生命周期由...

    hudson svn maven 自动构建

    【标题】"Hudson SVN Maven 自动构建"指的是在持续集成环境中使用Hudson(现在称为Jenkins)作为工具,结合Subversion(SVN)作为版本控制系统,Maven作为项目管理和构建工具,实现代码的自动构建过程。这个流程的...

    svn+maven插件(直接解压到{eclipse}\dropins即可)

    因此,对于任何使用Eclipse的Java开发团队来说,安装并配置好SVN和Maven插件都是必不可少的步骤。这个压缩包提供的插件无需额外安装步骤,只需简单解压,即可让Eclipse具备这两项强大的功能,是开发者便捷工作的好...

    内网离线安装jenkins+svn+maven自动化部署.zip

    本教程将重点讲解如何在内网环境下离线安装Jenkins,并结合Subversion(SVN)和Maven,实现持续集成与自动化部署。 首先,我们需要理解Jenkins。Jenkins是一款开源的持续集成服务器,它支持各种构建工具,如Maven,...

    Maven+SVN+jenkins集成环境配置

    在Java开发中,Maven和Jenkins的结合使用能实现高效的持续集成。当开发人员将代码提交到SVN仓库后,Jenkins可以通过监听SVN的钩子(hook)自动触发Maven的构建过程。Maven负责编译代码,运行单元测试,打包应用,...

    SVN管理软件+Maven小项目.rar_SVN管理软件+Maven小项目_svn

    在压缩包"SVN管理软件+Maven小项目"中,可能包含了如何配置和使用这两个工具的指南、示例项目以及可能的配置文件。通过学习这些材料,开发者可以更好地理解和应用SVN和Maven,提升其在软件开发中的实践能力。

    基于Maven+SVN自动打包

    本文将深入探讨如何结合Maven和SVN实现项目的自动打包流程,帮助开发者更有效地管理和部署代码。 【Maven】:Maven是一个强大的Java项目管理工具,它能够帮助开发者构建、管理和部署项目。Maven通过使用一个统一的...

    关于windows下jenkins+svn+maven+tomcat持续集成

    本文将详细介绍如何在Windows操作系统上配置一套基于Jenkins的持续集成环境,结合版本控制系统Subversion(SVN)、构建工具Maven以及应用服务器Tomcat,实现自动化构建和部署。 1. **Jenkins**:Jenkins是开源的...

    sonarqube jenkins svn maven代码质量检查.pdf

    这涉及到从版本控制系统中检出代码,使用Maven进行项目构建,通过Jenkins触发构建过程,并结合SonarQube进行代码质量的分析和报告。 整个集成工作流程大致如下: 1. 开发者在SVN中提交代码变更。 2. Jenkins通过...

    svn maven exp openExplorer adt egit 插件包

    本文将详细介绍标题中提到的几个关键工具:SVN、Maven、Eclipse(exp)、OpenExplorer、ADT以及EGit,并结合描述中的“link”安装方式进行讨论。 1. **SVN (Subversion)**:SVN是一种版本控制系统,用于跟踪和控制...

    hudson svn maven deploy BOM

    在开发环境中,Hudson经常与SVN结合使用,自动拉取最新代码并进行构建。 3. **Maven**:Apache Maven 是Java项目管理工具,它提供了标准化的项目结构和生命周期,简化构建过程。Maven通过依赖管理和项目信息管理,...

    maven+springmvc+mybatis+svn+hudson

    本文将详细讲解一个基于maven、springmvc、mybatis技术栈的电商项目,结合svn版本控制和hudson持续集成的实施过程。广西移动电子商城项目旨在构建一个网上商城,以应对通信行业竞争格局的变化,强化服务竞争力。系统...

    maven使用文档,maven使用文档

    - Maven 与版本控制系统(如 SVN)紧密结合,方便团队成员之间共享代码。 - 可以使用 Maven 插件来自动化 SVN 的操作,如自动提交构建结果到 SVN 等。 5. **IDE 集成** - Maven 可以很好地与 Eclipse 或 ...

    nexus+svn+jenkin_hudson+maven+禅道项目管理软件环境搭建一

    本篇将详细讲解如何结合Nexus、SVN、Jenkins(Hudson)、Maven以及禅道这五款工具,搭建一个适用于敏捷开发流程和持续集成理念的环境。这个环境能够极大地提升开发效率,简化项目管理流程。 **Nexus**: Nexus是一款...

Global site tag (gtag.js) - Google Analytics