项目管理实践【三】每日构建【Daily Build Using CruiseControl.NET and MSBuild】

在上一篇项目管理实践教程二、源代码控制【Source Control Using VisualSVN Server and TortoiseSVN】中我们已经讲解了如何使用TortoiseSVN和VisualSVN Server来做简单的版本控制,这一篇我们将会讲解使用CruiseControl.NET和MSBuild来搭建每日构建系统。

在第一篇项目管理实践教程一、工欲善其事,必先利其器【Basic Tools】 中我们已经安装了CruiseControl.NET 1.4,因为我们还要用到MSBuild,所以如果你的系统没有安装Visual Studio,那么你需要首先安装Visual Studio 2005/2008,我们在这里使用的是Visual Studio 2008,准备好这些了吗?OK,我们正式开始今天的课程! 

首先,我们要配置CruiseControl.NET【下面简写为CCNET】,配置完成后,我们每次提交源代码到SVN服务器后,CCNET就可以自动从SVN服务器上签出源代码,并调用MSBuild自动进行编译。我们以昨天的教程中创建的StartKit项目为实例,先看看下面的配置文件:

CCNET配置文件代码
1 <cruisecontrol xmlns:cb="urn:ccnet.config.builder">
  2    <!--项目名称-->
  3    <name>StartKit</name>
  4    <!--标示类型,有多种类型。下面为默认标示,作为每次编译时生成的日志文件的名称-->
  5    <labeller type="defaultlabeller">
  6        <!--前缀-->
  7         <prefix>StartKit-1-</prefix>
  8        <!--编译失败时是否增加-->
  9         <incrementOnFailure>false</incrementOnFailure>
 10       <!--格式-->
 11        <labelFormat>00000</labelFormat>
 12   </labeller>
 13   <!--项目的WebDashboard地址,CruiseControl.NET包括二部分,一是Server用来配置项目和监视文件修改,二是WebDashboard,是一个显示项目信息及编译信息的Website-->
 14       <webURL>http://202.196.96.55:8080/server/local/project/StartKit/ViewProjectReport.aspx</webURL>
 15   <!--触发器,包含多种,有兴趣可以查看官方文档-->
 16   <triggers>
 17   <!--时间间隔触发器,下面是60秒触发一次-->
 18         <intervalTrigger seconds="60" />
 19   </triggers>
 20   <!--如果发现修改,延迟多久开始编译,下面是2秒-->
 21   <modificationDelaySeconds>2</modificationDelaySeconds>
 22   <!--源代码控制系统,支持多种,有兴趣可以查看官方文档,下面采用svn-->
 23   <sourcecontrol type="svn">
 24   <!--源代码在SVN服务器上的路径-->
 25         <trunkUrl>http://zt.net.henu.edu.cn/svn/StartKit/StartKit/</trunkUrl>
 26   <!--svn服务器所在路径,在这里就是VisualSVN Server安装目录中的bin目录下的svn.exe -->
 27         <executable>C:/Program Files/VisualSVN Server/bin/svn.exe</executable>
 28     <!--用来迁出源代码的用户名,svn服务器进行验证-->
 29   <username>starter</username>
 30   <!--用来迁出源代码的用户名对应的密码-->
 31         <password>123456</password>
 32       <!--web获取源代码的地址,类似于开源网站上浏览代码的那部分功能,这里的类型是trac-->
 33   <!--<webUrlBuilder type="trac">
 34       <!--trac中对应项目的地址¬-->
 35         <tracProjectUrl>http://svn.net.henu.edu.cn/pojects/StartKit/</tracProjectUrl>
 36         <!--trac中对应项目的源代码库地址,相对于上面的路径-->
 37         <tracRepositoryRoot>/StartKit</tracRepositoryRoot>
 38         </webUrlBuilder>-->
 39   </sourcecontrol>
 40   <!--该节点用来配置具体执行那些任务-->
 41   <tasks>
 42   <!--msbuild任务配置,用来编译项目-->
 43         <msbuild>
 44           <!--MSBuild.exe的路径-->
 45           <executable>C:\WINDOWS\Microsoft.NET\Framework\v3.5\MSBuild.exe</executable>
 46           <!--从SVN迁出的源代码的存放位置,可以不配置,下面的即为默认值 -->
 47           <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 48           <workingDirectory>D:\Program Files\CruiseControl.NET\server\StartKit\WorkingDirectory</workingDirectory>
 49           <!--对这个项目的监控过程的日志记录目录,可以不配置,下面的即为默认值-->
 50           <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 51            <artifactDirectory> D:\Program Files\CruiseControl.NET\server\StartKit\ Artifacts</artifactDirectory>
 52           <!--要编译的项目名称 -->
 53   <projectFile>StartKit.sln</projectFile>
 54   <!-- MSBuild编译时的参数,具体参数信息可以查看MSDN上的说明-->
 55           <buildArgs>/p:configuration=debug</buildArgs>
 56           <!--指定日志记录模块-->
 57          <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 58           <logger>ThoughtWorks.CruiseControl.MsBuild.XmlLogger,D:\Program Files\CruiseControl.NET\server\ThoughtWorks.CruiseControl.MsBuild.dll</logger>
 59           <!--编译目标-->
 60   <targets />
 61         </msbuild>
 62           <!--在这里还可以添加其他的程序,比如运行测试、部署项目等等-->
 63   </tasks>
 64   <!--项目编译状态信息的保存位置-->
 65   <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 66       <state type="state" directory="D:\Program Files\CruiseControl.NET\server\CCState" />
 67   <!--发布和部署配置-->
 68   <publishers>
 69     <!--如果编译成功,那么下面的配置,会将源代码复制到指定目录HistoryVersion下,名称为版本标识(自动增长,labeller配置)的子目录下-->
 70     <buildpublisher>
 71       <!--源代码路径-->
 72       <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 73        <sourceDir> D:\Program Files\CruiseControl.NET\server\StartKit\WorkingDirectory </sourceDir>
 74        <!--编译成功后保存源代码到该目录下名称为版本标示labeller的目录中-->
 75       <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 76   <publishDir> D:\Program Files\CruiseControl.NET\server\StartKit\HistoryVersion </publishDir>
 77     </buildpublisher> 
 78   <!--该节点用来配置合并多个文件,当时有外部插件时,要把他们分别产生的输出文件合并--> 
 79         <merge>
 80           <!--要合并的文件,合并后的信息可以显示在Web Dashboard和邮件通知里-->
 81           <files>
 82               <!--我这里的CruiseControl.NET 安装在D盘,你们使用时候,改成自己的安装路径即可-->
 83             <file>D:\Program Files\CruiseControl.NET\server\StartKit\WorkingDirectory\results.xml</file>
 84           </files>
 85         </merge>
 86           <!--源代码路径-->
 87         <xmllogger />
 88           <!--显示历史修改记录列表, 在Web Dashboard中可以查看-->
 89        <modificationHistory />
 90          <!--所有编译信息的统计, 在Web Dashboard中可以查看-->
 91         <statistics />
 92           <!--邮件通知配置,每次编译后,都会邮件通知下面配置中添加的用户-->
 93         <!-- mailhost是发送邮件的主机,mailport是邮件发送端口,mailhostUsername发送邮件的邮箱用户名,mailhostPassword发送邮件的邮箱密码,from希望显示在发件人中的邮箱地址, includeDetails邮件内容是否包含详细的编译信息 -->
 94   <email mailhost="smtp.qq.com" mailport="25"
 95                    mailhostUsername="******" mailhostPassword="******" from="******@qq.com" includeDetails="true">
 96           <!--接收邮件通知的用户 -->
 97   <users>
 98     <!--name是SVN服务器上存在的用户名,group是SVN服务器上存在的组,address是该用户的邮箱地址 -->
 99             <user name="zt" group="StartKit" address="******1@qq.com" />
100            <user name="***" group="StartKit" address="******2@qq.com" />
101           <user name="***" group="StartKit" address="******3@qq.com" />
102          </users>
103          <!--接收邮件通知的组-->  
104        <groups>  
105          <!--name必须是SVN服务器上存在的组,notification是什么时候发送通知,可选有Always/Success/Change/Fixed/Failed --> 106           <group name="StartKit " notification="always" /> 107          </groups>  
108        </email>  
109      </publishers>  
110    </project>  
111  <!--可以同时添加多个项目  
112  <project >  
113  <name>test</name>  
114  ……  
115  </project>  
116  -->  
117  </cruisecontrol

好了,我们已经对CCNET的配置文件有了大致的了解,接下来,你打开CCNET的安装路径,找到子目录server下的ccnet.config文件,把上面的配置信息Copy到ccnet.config文件中,记得把配置文件中的一些路径修改为自己的实际路径啊,修改好后,保存。这时候,检查Windows服务CruiseControl.NET Server是否启动,如果没有则启动它,启动该服务后,打开浏览在地址栏输入上面配置文件中的webUrl地址:http://202.196.96.55:8080/server/local/project/StartKit/ViewProjectReport.aspx 也可以直接输入http://202.196.96.55:8080/server/ ,这里是演示地址,要根据自己的实际情况修改为正确的地址,OK,看到类似下图的效果,好了,搞定!如果你遇到了什么麻烦,请在下面留言,我一定会及时回复!
点击StartKit,转入下图所示的页面:
OK,到这里,我们提交更新到SVN服务器后,CCNET就会根据我们配置自动编译项目,而且我们也可以通过Web Dashboard来查看具体的编译信息了,提示如果配置了邮件发送,那么我们还可以通过邮件收到详细的编译信息,怎么样?够方便吧!

其实,CCNET的功能是相当强大的,上面只是最常用的配置,其他还有很多非常好的功能。你想知道吗?那你可以在这里查看CCNET官方文档 ,实际上,你安装CCNET后,文档也已经安装到你的电脑了,在CCNET的安装目录下的webdashboard的子目录doc中就是。

好了,我们今天的教程就到这里,本来我应该把如何使用CruiseControl.NET Tray来监视每次更新后的编译状态,但是今天真的太晚了,明天还要做项目,所以我明天补上,请大家见谅!
补充部分:
下面我简单讲一下,如何使用CruiseControl.NET Tray【以下简称CCTray】来监视每次提交后的编译状态。
安装好打开CCTray后,运行CCTray程序,点击左上角的菜单File下的Settings…,如下图:

点击Settings…会弹出下面的窗体:

切换到Build Projects选项卡,如下图:

点击Add…按钮,添加我们的CCNET服务器,如下图:

输入我们的CCNET服务器后,CCNET服务器上的项目就会在右侧显示出来,如下图:

选中右侧的项目后,点击OK按钮,返回CCTray打开时的界面,我们的二个项目已经添加进来了,如下图:

我们在桌面的右下角的任务栏,可以看到如下图所示的图标:

绿色的那个标示就是CCTray的标示,绿色表示所有的项目都通过了编译,紫红色表示至少有一个项目没有通过编译,橘黄色表示有项目正在编译,橘红色表示有项目被强制编译,显示为灰色则说明和CCNET服务器失去了链接。

OK,大家可以使用CCTray实时监视提交更新后项目的编译状态了。

如果大家有什么问题,欢迎和我交流!

 

时间: 2024-09-13 15:40:05

项目管理实践【三】每日构建【Daily Build Using CruiseControl.NET and MSBuild】的相关文章

在.NET环境中实现每日构建(Daily Build)--ccnet,MSBuild篇

每日构建,对我们团队来说一个全新的概念.随着项目开发的进展,在开发过程需要及时反馈一些BUG 和功能要求的处理情况.而在这种情况下每天或隔一段时间Build一个版本,工作量还是比较大的,所以 就特别有必要引入每日构建.关于每日构建,在园里有已经有很多的文章了,特别是摩诘的<在.NET环境 中实现每日构建(Daily Build)--NAnt篇>更是从概念上和实践上手把手地介绍如果在.NET环境下实现每 日构建.但很遗憾,在我实现每日构建之前没有看到这篇文章,错失了一次快速入门的机会,不过感到庆

项目管理实践【五】自动编译和发布网站【Using Visual Studio with Source Control System to build and publish website automatically】

在上一篇教程项目管理实践[三]每日构建[Daily Build Using CruiseControl.NET and MSBuild] 中,我们讲解了如何使用CCNET+MSBuild来自动编译项目,今天我们讲解一下怎么使用MSBuild+WebDeployment+Robocopy自动编译过和部署ASP.NET网站. 首先安装下面的三个软件: 1.MSBuild.Community.Tasks下载:http://msbuildtasks.tigris.org/files/documents/

《配置管理最佳实践》——2.11 持续集成与每日构建

2.11 持续集成与每日构建 持续集成是一个相当流行的软件开发实践.现在,人们时常把持续集成和敏捷开发联系到一起.实际上,即使开发团队使用的不是敏捷开发的过程, 持续集成在他们之间也已经非常流行.另外一个很明显的现象是很多研发团队并不需要签入构建(commit build, check-in build),也就是说并不需要每次有代码签入代码库都要立刻触发一个构建.很多时候,每日构建已经足够用了,而且也容易实现.持续集成经常会发起很多没必要的失败构建,导致显示面板上出现很多没必要的失败记录.某些构

项目管理实践【六】自动同步数据库【Using Visual Studio with Source Control System to synchronize database automatically】

在上一篇项目管理实践[五]自动编译和发布网站中,我们讲解了如何使用MSBuild+Robocopy+WebDeployment来自动编译和部署网站,今天,我们来看一下,如何使用MSBuild +SVN来自动同步数据库. 首先,将我们项目中的数据库文件和数据库日志文件放到某个目录下,这里放到StartKitDB目录下,然后在该目录下新建一个名为StartKitDB的文本文件,修改扩展名为proj,实际上,在理论上任何扩展名都可以,然后,使用记事本或其他程序打开文件,将下面的内容复制到其中,保存.

项目管理实践教程一、工欲善其事,必先利其器【Basic Tools】

今天,我们首先安装一些必须的软件,主要有下面的4个,其中软件1和2使用在服务器机上,软件3和4安装在客户端机上.另外,我们还有用到MSBuild.RoboCopy.WebDeployment等等,在下面的文章中用到的时侯,我会介绍给大家.      软件 最新版本 简单说明 1 VisualSVN Server 1.6.1   版本控制.用户及权限管理 2 CruiseControl.NET 1.4 每日构建服务器端 3 TortoiseSVN 1.5.5.14361 版本控制客户端 4 Cru

200分(我只能发100分的帖子)求答案 每日构建

问题描述 我想做的是用svn+ant+cruiseControl来实现每日构建.我用ant从SVN服务器下载项目,然后用cruiseControl来定时构建.部署这个项目,再发邮件通知管理员有关这个项目的构建情况.请问谁能给我讲讲具体的步骤和过程,能结合小实例讲就更好了,求高人帮忙解决问题啊! 解决方案 解决方案二:该回复于2011-04-08 11:28:58被版主删除解决方案三:不懂,坐等高人的解决,学习思路....解决方案四:该回复于2011-04-08 14:41:57被版主删除解决方案

为iOS项目添加Daily Build

很多人在说到Daily Build的时候总是喜欢背书.背书就背书吧,总比混迹软件行业连书都没看过的强.很久以前遇到一个奇葩.每次到代码提交测的通知就着急忙慌的催促组员赶紧干活,开始严重加班,晚饭都不吃...偶尔还需要开通宵.但是即使如此,最后也不会得到什么好的反馈.那个team就是这样循环往复的做着项目,直到永恒.如果项目的相关人员能背背敏捷什么的开发书籍,想必情况总能有所改善. 相信以上情况各位多少都遇到过,那么Daily Build为什么会对这样的情况有所改善呢? 快速定位错误.那天的Dai

每日构建和冒烟测试

谈每日构建都会连带谈冒烟测试这个词.每日构建不是简单的指每日编译,编译和构建完成后必须对增加的新功能点进行系统测试,对已经测试过的功能点进行冒烟测试.每日构建是微软比较推荐的最佳实践,强调测试的早期介入和持续的版本集成. 每日构建和冒烟测试的优点主要有: 1.进度可见并可以控制到1-2天的细粒度,很容易看到进度的偏差 2.及早的发现开发BUG和缺陷并分析解决,对开发人员的一种监督和促进,提高软件质量 3.由于将大集成分解到每日构建中的小集成,避免了传统产品集成或集成测试时候出现的严重问题的可能.

项目管理实践教程二、源代码控制【Source Control Using VisualSVN Server and TortoiseSVN】

在第一篇文章 项目管理实践教程一.工欲善其事,必先利其器[Basic Tools]发布后,根据大家的回复,我需要向大家说明几个问题: 1.为什么要用VisualSVN Server,而不用Subversion? 回答: 因为如果直接使用Subversion,那么在Windows 系统上,要想让它随系统启动,就要封装SVN Server为windws service,还要通过修改配置文件来控制用户权限,另外如果要想以Web方式[http协议]访问,一般还要安装配置Apache,如果是新手,岂不是很