使用maven,svn和CruiseControl做持续集成

最近抽空继续整理先前的文档,呵呵.两年多工作中学习到的东西还是蛮多的哦.

一.背景

1.1. 大背景

持续集成,公司需要,项目也需要.

1.2.小背景

代码存储在svn库上,并且每天都有改动.

项目使用maven来做打包构建.先前做cruisecontrol时虽然解决了以ant,svn方式做持续构建的代码更新与构建问题,但在已有项目中,没有ant可用的build.xml,且整个项目实际上由多个小项目组成.使用ant来做build的话,不方便.

1.3.cruisecontrol介绍

略,先前已有介绍.

二.如何做

2.1.前提条件

1.安装了maven且maven做build所需的仓库已有.

2.安装了svn客户端,且svn的环境信息已加入到了系统path路径中

ant中,可以使用svnant来做svn代码更新,这只是3个jar就能解决,但使用maven做build时,暂时无法使用ant脚本.因此必须安装svn客户端.

在cruisecontrol调用maven做版本构建前,先要从svn同步代码下来,如果本地没有svn客户端,或者没找到,则代码同步无法进行,版本构建会出错.

在做完svn的配置后,去控制台,输入svn,在确认能认出这个svn程序后,再做后面的操作.

3.确保自己有一个svn账号,并且获知了要做版本构建的目录(即project的目录)

2.2 cruisecontrol的配置

本质上就是去在cruisecontrol的config.xml文件中添加相应的项目构建配置信息.此处只列出关键配置点.

2.2.1 项目build之前做配置文件同步

bootstrappers用来在项目build之前做主要配置文件的更新,如build.xml,build.propertis,pox.xml.在bootstrappers底下添加svnbootstrapper来告诉cruisecontrol主要配置文件使用svn来做更新.其中localWorkingCopy用来指明本地的主要配置文件的目录,不过为了更保险起见,可以用file来代替,file是用来指明主要配置文件是哪个文件.

<bootstrappers>

<svnbootstrapper localWorkingCopy="${checkout_dir}" username="${svn_user}" password="${svn_passwd}"/>

</bootstrappers>

类似${checkout_dir}这样的值是先前定义的变量值.可以使用<property name="checkout_dir" value="projects/datamatrix-1.0.0-dev4/${project.name}"/>这种方式在先前定义变量值,这样比较易于维护.

2.2.2 modificationset的配置

modificationset用来指定要监控哪些文件会更改(默认情况下,如果第二次build开始,cruisecontrol发现要build的文件集没有改动,则会跳过build过程,直接完成本次build)

<modificationset quietperiod="30">

<svn localWorkingCopy="${checkout_dir}" username="${svn_user}" password="${svn_passwd}"/>

</modificationset>

上面的配置项告诉cruisecontrol,本地文件在localWorkingCopy目录下,是否有变动,可以通过svn去检查.

2.2.3 定时调度

白天编译和打包的服务器大家很多人和程序在用,压力较大;而晚上大家下班后压力很小,做定时编译打包是个好时机.

在cruisecontrol中设置定时调度,是通过在schedule节点下添加pause节点来实现的.

最后举一个例子:

<schedule interval="60">

<maven2 mvnhome="${M2_HOME}" pomfile="${pomfile}" goal="clean package site" />

<pause starttime="0600" endtime="2300"/>

</schedule

这个例子表示在6点至23点这段时间,暂停当前的调度任务,这个时间段内,不会有build任务执行.

可以给一个schedule底下添加多个pause,即可以设置多个不做build的时间段.

2.2.4 邮件告警配置

略,先前已有介绍.

三.一些体会

1.cruisecontrol只是起到了一个定时调度功能,要编译打包还是要靠maven,因此,为了保证能通过编译和打包,maven相关的配置一定要做好.

2.cruisecontrol每次启动前会检测要build的项目,在项目的循环调度周期的时间之后才开始执行调度,而非一启动就开始调度.因此做定时调度时,这一点要注意到

3.cruisecontrol在下次调度时候会检查config.xml是否有变动,因此添加进一个新的project来做持续集成时,没必要将cruisecontrol停止.

四.附件

config.xml的一个例子

无标题

原文地址:https://www.cnblogs.com/leipei2352/p/2430639.html