hudson学习笔记

持续集成(CI)是一种实践,旨在缓和和稳固软件构建过程。

一、持续集成的好处:

•软件构建自动化:使用CI,您只要按一下按钮,它会依照预先制定的时间表,或者响应某一特定事件,就开始进行一次构建过程。如果您想取出源码并生成构件,该过程也不会局限于某一特定IDE、电脑或者个人。

•持续自动的构建检查:CI系统能够设定成持续地对新增或修改后签入的源代码执行构建,也就是说,当软件开发团队需要周期性的检查新增或修改后的代码时,CI系统会不断要求确认这些新代码是否破坏了原有软件的成功构建。这减少了开发者们在手动检查彼此相互依存的代码中变化情况需要花费的时间和精力(说直接一点也是钱啊,呵呵)。

•持续自动的构建测试:这个是构建检查的扩展部分,这个过程将确保当新增或修改代码时不会导致预先制定的一套测试方案在构建构件后失败。构建测试和构建检查一样,失败都会触发通知(Email,RSS等等)给相关的当事人,告知对方一次构建或者一些测试失败了。

•构件生成后续过程的自动化:一旦自动化检查和测试的构建已经完成,一个软件构件的构建周期中可能也需要一些额外的任务,诸如生成文档、打包软件、部署构件到一个运行环境或者软件仓库。只有这样,构件才能更迅速地提供给用户使用。

二、CI服务器结构

实现一个CI服务器你需要的最低要求是,一个易获取的源代码仓库(包含源代码),一套构建脚本和流程和一系列围绕构件构建的可执行测试。

该系统的各个组成部分将按如下顺序来发挥作用:

1.开发者检查新增和修改到源代码仓库后的代码。

2.CI服务器会为每一个项目创建了一个单独的工作区。当预设或请求一次新的构建时,它将把源代码仓库的源码存放到对应的工作区,在哪里构建就执行到哪个目录下。

3.CI服务器会在新近创建或者更新的工作区内执行构建过程。

4.一旦构建完成,CI服务器就会在一个新的构件中选择性地执行原先定义的一套测试。如果构建失败,相关责任人将会通过电子邮件、即时短信或者其他的方式获取到(失败)通知。

5.如果构建成功,这个构件会被打包并转移到一个部署目标(如应用服务器)和/或存储为软件仓库中的一个新版本。这个如软件仓库可以是CI服务器的一部分,也可以是一个外部的仓库,诸如一个文件服务器或者像Java.net、SourceForge分发的一个有效网址。源代码仓库和构件仓库是可以分开的,实际上它可以利用一些根本没有包含任何源代码控制系统(CVS、SVN、CSS等等)的CI服务器。

6.CI服务器通常会通过某种控制台来进行项目的配置和调试,并且根据请求响应相应的操作,诸如即时构建、生成报告,或者检索构件。

构件:构建完成后的软件成品,如JAR或WAR等。

三、Hudson优点:

1.支持的SCM(源码控制管理),Hudson完全支持与Subversion的集成,也只需少量配置就可以把CVS集成在一起,

2.基于Web的用户界面非常友好、直观和灵活,在许多情况下,还对需单独配置的部分提供了基于AJAX的即时反馈。

3.Hudson是基于java开发的(如果你是一个Java开发人员,这是非常有用的)。

4.Hudson本身是一个很简洁的组件,但它提供了一组很明确和可扩展API的Hudson组件。这批组成一个大的类库的Hudson组件反过来又丰富了Hudson的功能;它们都是开源的,而且它们可以直接通过Hudson的控制台来进行安装。

四、安装Hudson:WindowsXP

使用Hudson,您需要一个方便和可支持的源代码控制系统,该文件是以JavaEE的Web归档模式(war)存在]。启动该服务器很简单,只需执行下面的命令行:

C:\hudson>java-jarhudson.war

这可能是较普通的做法,然而,我们一般会把Hudson部署到一个基于Servlet的2.4和JSP2.0规格的Javaservlet容器里,如GlassFish,Tomcat,JBoss和Jetty。

部署Hudson很简单,只需要你把hudson.war复制到/home/jboss/jboss/server/default/deploy下。你最好是使用JBoss用户,这样才能确保JBoss服务器有权限读取该文件。Hudson应该在几秒钟内就会部署完毕。然后你可以通过在浏览器中输入http://localhost:8080/hudson来验证Hudson是否安装成功。

五、hudson构建:

前置条件

如果您想在Hudson完成一次构建,必须符合下列条件:

•您必须拥有一个可用的源代码仓库。

•这个仓库必须包含你想要构建的源代码。

•仓库里必须包含能构建源码的构建脚本。它们通常来源于Ant或者Maven

相关推荐