设为首页 收藏本站
查看: 1060|回复: 0

[经验分享] CruiseControl初探

[复制链接]

尚未签到

发表于 2017-2-19 07:11:13 | 显示全部楼层 |阅读模式
    一.背景

  CruiseControl从<项目自动化之道>这本书中了解到,然后又从网上查资料做了一定尝试.同时,项目持续集成这部分我也计划在自己参与的项目上先试点实行,才有了这篇文章. 二.CruiseControl 是什么

  简单点说,就是一个项目自动构建,持续集成工具和框架(为什么我叫它框架,是因为CruiseControl可以支持很多第三方扩展,而且也不只是能build java应用,比如.net,不过.net的CruiseControl被改名成CruiseControl.NET了). 三.为什么用它

  1.开源免费,sourceforge上就可以下载到;
  2.出来的时间较早,1.0版本出现在2001年,现在已经发展到了2.8版本了,部署使用的参考内容比较多;
  3.包含许多不同类型代码控制的插件和支持许多第三方工具(这部分我还没去做尝试);
  4.在java产品的版本构建上支持跨平台;
  5.项目自身而言,使用自动构建和定时构建,能在此基础上持续改进,提升产品质量; 四.模块及体系结构
4.1 模块

  CruiseControl 主要分3个模块:
  1. build loops :后台功能,是CruiseControl的核心,定期调度CruiseControl中定义的要去build的项目,执行build.
  2. dashboard: 一个web应用中的前端模块,使用者通过这个web页面可以获取到当前CruiseControl中的项目的build的状态等一些基础信息.如下图:
DSC0000.jpg
  3. jsp reporting: 一个web应用中的前端模块 ,使用者在这个模块的页面中可以看到先前每个project build之后生成的详细信息.如下图:
DSC0001.jpg 4.2 CruiseControl的体系结构

DSC0002.jpg 五.运行原理

  在CruiseControl的config文件中定义要持续集成的project,之后CruiseControl每隔一段时间就去轮询config文件,根据config文件中最新的配置去调用build工具去执行版本构建任务,这时候CruiseControl就会记录下版本构建的结果,构建过程中生成的日志,根据构建结果来执行其它操作,比如给相关人员发送邮件等. 六.安装部署
6.1 系统需求

  1.操作系统
  根据CruiseControl所包含的文件来看,CruiseControl支持在linux,unix和windows上运行.我本次是在windows上做了部署和build试验.在Solaris上只做了CruiseControl的部署,没有做project的build试验.
  2.java环境
  必须安装JDK,要设置JAVA_HOME环境变量,并且将$JAVA_HOME/bin加到了PATH路径中.
  3.端口准备
  默认情况下,CruiseControl启动后要占用操作机器上的8000端口给jmx用,8080端口供web访问用,1099端口给rmi用.所以需要提前确认这些端口没有被系统中其他程序占用.当然,也可以直接去修改启动的bat或者sh文件.
  4.权限问题
  在linux,unix等机器上,要确保对应的.sh是可执行的. 6.2 部署程序

  cruisecontrol-bin-2.8.4.zip解压后运行cruisecontrol.bat即可(如果端口冲突,请改端口). 6.3 验证部署结果

  运行成功后访问http://ip:port/dashboard,页面能显示connectfour这个project就说明部署正常.
  在dashboard上面看见绿色的图块,鼠标放上去,看见Project: connectfour上次build成功,则说明现在一切正常,可以把自己的project放过来,做版本持续集成了.
DSC0003.png 七.部署自己的第一个java project

  1.在eclipse中创建一个java project,名称为myProject
  2.创建一个java类HelloWorld,位于cn.com.carnation包下,类的代码如下:

  package cn.com.carnation;
  public class HelloWorld{
  public HelloWorld(){
  super();
  }
  public String getHelloWorld(){
  return "Hello,world!";
  }  }

  3.构建ant编译时所用的build.xml配置文件,内容如下:

  <project name="myProject" default="all" basedir=".">
  <property file="build.properties"/>
  <path id="project.classpath">
  <pathelement location="${svnjavahl.jar}" />
  <pathelement location="${svnant.jar}" />
  <pathelement location="${svnClientAdapter.jar}" />
  </path>
  <target name="all" depends="clean, compile, sleep, jar"/>
  <target name="clean">
  <delete dir="target" quiet="true" />
  </target>
  <target name="compile" >
  <mkdir dir="target/classes"/>
  <javac srcdir="src" destdir="target/classes">
  <classpath>
  <pathelement location="build/lib/${app.name}.jar" />
  <pathelement path="${basedir}/lib" />
  </classpath>
  </javac>
  </target>
  <target name="sleep">
  <echo message="Sleeping for a while so you can see the build in the new dashboard" />
  <sleep seconds="5" />
  </target>
  <target name="jar" depends="compile">
  <jar jarfile="target/myProject.jar" basedir="target/classes"/>
  </target>  </project>

  4.先手动执行一次,确认可以成功编译
  在cmd下进入myProject 目录,使用ant来build一个版本
  5.将这个project加入cruisecontrol的配置文件config.xml中,添加的代码如下:
DSC0004.png

  6.等待一段时间, cruisecontrol会自动将新加进配置的project进行build,等待的时间从目前来看,是原有的project轮询的时间与当前时间的差值.

DSC0005.jpg 八.其它问题
8.1从svn获取要build的版本

  从svn获取要build的版本,是持续集成的最重要的一步.
  要从svn获取要build出来的版本,ant已经可以做到. Subclipse组织提供了一个名为svnant的project ,专门用来做ant在构建版本时从svn更新代码的操作.具体内容,可以参考官方网站:http://subclipse.tigris.org/svnant.html.
  我只在此处列出一个可以的样例来说明怎样在版本构建前更新本地的代码:
  1. build.xml中新加进去的部分
  解释:先通过导入build.properties文件中的一些定义,通过这些定义,将svnant所需的三个jar文件加载到了一个path元素中,最后定义好要连接的svn的url目录,用户,密码,要迁出的目标目录.然后再定一个一个ant task,在里面做svn的代码迁出.

  <property file="build.properties"/>
  <path id="project.classpath">
  <pathelement location="${svnjavahl.jar}" />
  <pathelement location="${svnant.jar}" />
  <pathelement location="${svnClientAdapter.jar}" />
  </path>
  <property name="svn_User" value="***"/>
  <property name="svn_Password" value="***"/>
  <property name="svn_url" value="svn://******/myProject" />
  <property name="desdir" value="${basedir}" />
  <taskdef resource="svntask.properties" classpathref="project.classpath"/>
  <target name="update">
  <svn>
  <checkout url="${svn_url}" revision="HEAD" destPath="${basedir}" />
  </svn>  </target>

  2. build.properties文件中的内容

  svnant.version=1.0.0
  lib.dir=D:\program files\apache_org\apache-ant-1.8.2\lib
  svnant.jar=${lib.dir}/svnant.jar
  svnClientAdapter.jar=${lib.dir}/svnClientAdapter.jar  svnjavahl.jar=${lib.dir}/svnjavahl.jar
8.2设置发送邮件
8.2.1 介绍

  CruiseControl中可以在每个要持续集成的project的配置中添加邮件通知.这样即使项目组员没有在公司,也可以获取到版本构建的情况.
  1. 在CruiseControl中,发送的邮件分为两个格式:普通格式和html格式,对应的配置是email和htmlemail.
  2. email或者htmlemail在配置中的位置
  email配置点是project的publisher元素下的子元素. 8.2.2一个具体的例子

  1. 以下是CruiseControl的config.xml文件中关于邮件通知的配置:
DSC0006.png
  2. 配置说明:
  1. mailhost用来指定邮件服务器,mailport用来制定端口,smtp邮件服务器的服务端口是25.username和password是用来发送build结果邮件的用户.reportsucess是表示在邮件中一直报告build成功的结果,默认就已经是取了always的值.
  2. email的子元素<always>包含的值是一个电子邮件地址,表示不论build的结果如何,都将接收邮件.一个email可以包含0到多个always的子元素. <success>子元素包含的电子邮件地址是.build成功后的邮件接收人. <failure>子元素包含的电子邮件地址是build失败后的邮件接收人.
  3. 邮件结果
DSC0007.jpg 8.3 远程控制部署project

  1. 进入CruiseControl的dashboard页面中,有tools区域,如下所示:
DSC0008.png
  2. 点击cc-config,调用java运行远程方法,在本地打开一个swing的界面的管理监控器(CruiseControl config/Monitoring tool),在其中可以管理CruiseControl的project.这部分内容后面会补充.
DSC0009.jpg
  图8.3.1 监控和管理现有project
DSC00010.png
  图8.3.2添加一个project 九.后续需解决问题
9.1 CruiseControl config/Monitoring tool 的使用以及在实际中的应用

  这一块的功能现在只是有大体上的了解,还未具体实践过. 9.2 build过程中进行单元测试

  单元测试在持续版本构建中必须要做,先前是手工做版本构建,现在实行自动构建,则单元测试部分需要加大力度去做,但这部分有遗留问题存在.因此需要特别考虑. 9.3 通知邮件的内容丰富

  现有配置的通知邮件的内容只是告诉接收者build是否成功,然后就是一个url连接.而且这个url连接现在点击打开之后会访问出错.因此价值还不是很大.
  除了通知build结果外,最好是把build过程中的日志特别是出错日志附带到邮件正文或者附件中,这样才能有更高的价值. 9.3将build好的版本部署到web服务器上

  最好是将通过单元测试的包上传到web服务器上,部署到weblogic下,并且能自动启动weblogic.
  
  
  后记:
  1.文章第一次发出来,发现其中一张配置的图片中还有我的公司邮箱的配置,泄漏个人隐私和公司机密,哎,差点傻逼了啊.
  2.其实cruisecontrol支持在build之前自己去svn上checkout代码,而不用依赖svnant的.下一篇文章中我会列出来.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-343994-1-1.html 上篇帖子: jsp 编码问题总结 下篇帖子: 性能测试(并发负载压力)测试分析-Loadrunner
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表