CONAN ZONE

          你越掙扎我就越興奮

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            0 Posts :: 282 Stories :: 0 Comments :: 0 Trackbacks

          一.什么是持續(xù)集成

          持續(xù)集成的核心概念

          CI 過程會(huì)經(jīng)常構(gòu)建軟件組件;在許多情況下,每當(dāng)源代碼存儲(chǔ)庫(比如 Subversion 或 ClearCase)中的代碼發(fā)生變化時(shí),都要構(gòu)建軟件組件。CI 的好處是:經(jīng)常構(gòu)建軟件可以確保盡早遇到問題(比如代碼缺陷),避免問題在軟件開發(fā)周期晚期變復(fù)雜時(shí)才被發(fā)現(xiàn)。

          工具與過程

          盡管 CI 實(shí)際上是一個(gè)過程,但是持續(xù)集成 這個(gè)詞常常與一個(gè)或多個(gè)工具相關(guān)聯(lián)。在本教程中,講解如何安裝、配置和使用 Hudson 作為 CI 服務(wù)器,但是要記住,CI 遠(yuǎn)不只是個(gè)工具。實(shí)際上,使用的工具可能是 CI 比較次要的方面,因?yàn)?CI 工具所做的僅僅是在代碼存儲(chǔ)庫中探測到修改時(shí)運(yùn)行構(gòu)建。構(gòu)建過程本身比用來運(yùn)行它的工具重要得多。

          開始使用 CI

          開始使用 CI 需要三個(gè)組件:

          • 用 Ant 或 Maven 等工具建立的自動(dòng)構(gòu)建過程
          • 一個(gè)代碼存儲(chǔ)庫,比如 CVS 或 Subversion
          • 一個(gè) CI 服務(wù)器,比如 Hudson,但是 cron 作業(yè)也可以滿足需要

          我們來詳細(xì)討論這些組件。

          自動(dòng)的構(gòu)建

          CI 過程會(huì)經(jīng)常集成軟件,這需要通過構(gòu)建來完成。在 Java 環(huán)境中,Ant 是常用的構(gòu)建平臺(tái)??梢允褂?Ant 可靠地自動(dòng)執(zhí)行編譯、測試等任務(wù),甚至可以執(zhí)行軟件檢查和部署。在掌握了 CI 的所有組件之后,您會(huì)發(fā)現(xiàn)構(gòu)建策略是成功的 CI 過程最重要的方面。如果缺少適當(dāng)?shù)臉?gòu)建過程,CI 就難以發(fā)揮作用。

          源代碼管理

          為了讓 CI 正確地發(fā)揮作用,需要一個(gè)源代碼管理(SCM)系統(tǒng)或存儲(chǔ)庫,比如 Subversion 或 CVS。CI 服務(wù)器向 SCM 存儲(chǔ)庫查詢代碼修改。在找到修改時(shí),CI 服務(wù)器執(zhí)行簽出(即更新本地沙箱)并執(zhí)行構(gòu)建。除了執(zhí)行得更頻繁之外,構(gòu)建過程與在本地環(huán)境中執(zhí)行的構(gòu)建相同。

          CI 服務(wù)器

          對(duì)于成功的 CI 過程,需要用一個(gè)自動(dòng)的過程監(jiān)視 SCM 存儲(chǔ)庫并在探測到修改時(shí)運(yùn)行構(gòu)建,這也非常重要。對(duì)于 Java 平臺(tái),有許多可用的 CI 服務(wù)器,包括開放源碼軟件和商業(yè)產(chǎn)品。它們的基本配置都很相似,適合監(jiān)視特定的 SCM 并在探測到修改時(shí)運(yùn)行構(gòu)建。所有 CI 服務(wù)器都有自己的優(yōu)缺點(diǎn)。Hudson 尤其讓人感興趣,因?yàn)樗菀着渲枚揖哂袕?qiáng)大的插件,這些插件可以顯示測試結(jié)果趨勢等信息。

          二.Hudson 簡介

          Hudson 是一種革命性的開放源碼 CI 服務(wù)器,它從以前的 CI 服務(wù)器吸取了許多經(jīng)驗(yàn)教訓(xùn)。Hudson 最吸引人的特性之一是它很容易配置:很難找到更容易設(shè)置的 CI 服務(wù)器,也很難找到開箱即用特性如此豐富的 CI 服務(wù)器。Hudson 容易使用的第二個(gè)原因是它具有強(qiáng)大的插件框架,所以很容易添加特性。例如,一個(gè) Hudson 插件可以隨時(shí)間的推移跟蹤 FindBugs 和代碼覆蓋。它還可以報(bào)告測試結(jié)果的趨勢(來自 JUnit 或 TestNG)以及構(gòu)建結(jié)果和對(duì)應(yīng)的執(zhí)行時(shí)間。

          Hudson 需要運(yùn)行 Java 5。如果需要使用 Hudson 附帶的嵌入式容器(Winstone)之外的其他容器,那么只需使用一種 Servlet 2.4 容器。對(duì)于大多數(shù)情況,Winstone 就足夠了。

          三.Hudson使用

          CI 過程的最后一個(gè)方面是 CI 服務(wù)器本身。CI 服務(wù)器在整個(gè)開發(fā)過程中的主要作用是控制者:當(dāng)服務(wù)器在代碼存儲(chǔ)庫中探測到修改時(shí),它將運(yùn)行構(gòu)建的任務(wù)委托給構(gòu)建過程本身。如果構(gòu)建失敗了,那么 CI 服務(wù)器將通知相關(guān)方面,然后繼續(xù)監(jiān)視存儲(chǔ)庫。它的角色看起來是被動(dòng)的;但是,它是快速反映問題的關(guān)鍵。

          安裝 Hudson

          使用 Hudson 的主要好處之一是它的設(shè)置很簡單。在最簡單的情況下,Hudson 只需要兩個(gè)步驟:

          1. 下載最新的版本(它打包為一個(gè) WAR 文件)。 hudson官方網(wǎng)址:https://hudson.dev.java.net/
          2. 運(yùn)行 java -jar hudson.war。

          這樣就可以了。因?yàn)橄螺d的是一個(gè) WAR 文件,所以如果愿意,可以將它部署在 Tomcat 或 JBoss 等容器中。這完全由您自己決定。當(dāng)然,Hudson 假設(shè)在安裝它的機(jī)器上運(yùn)行著 Java 5,而且如果定義了 JAVA_HOME 環(huán)境變量,Hudson 就會(huì)使用它。(正如前面提到的,Hudson 需要 Java 5。)

          在安裝并運(yùn)行 Hudson 之后(將 WAR 文件部署到 servlet 容器或從命令行執(zhí)行 java -jar hudson.war),啟動(dòng)瀏覽器并訪問默認(rèn)安裝位置。如果通過命令行運(yùn)行 Hudson 而且您在本地機(jī)器上,那么可以訪問 http://localhost:8080/。


          如果一切正常(實(shí)際上不太可能出問題),應(yīng)該會(huì)看到圖 2 所示的 Hudson 啟動(dòng)頁面。

          配置 Hudson

          如果訪問 Hudson 主頁的本地實(shí)例并單擊左上角的 Manage Hudson 鏈接,應(yīng)該會(huì)看到圖 3 所示的可配置選項(xiàng)列表。

          圖 3. 配置 Hudson 非常容易

          參數(shù)說明:
          system.message 填寫一些說明信息
          Quiet period:hudson定時(shí)構(gòu)建工程的時(shí)間(秒)
           :設(shè)置hudson登陸的規(guī)則(默認(rèn)為匿名登陸)
          TCP port for JNLP slave agents:不了解JNLP不敢胡寫總之就是三種方式:固定(fixed) 隨機(jī)(Radom) 不使用(disabled),使用固定時(shí)可以填入JNLP信息

          security realm:可以使用中間件容器,數(shù)據(jù)庫,LDAP來驗(yàn)證安全,具體怎樣用法沒用過,以后會(huì)有更新,研究中.
          authorized:可以設(shè)置身份的驗(yàn)證方法:系統(tǒng)用戶,匿名用戶,自定義用戶,還有繼承用戶(此處也在研究中,建議使用匿名用戶)
          JDK installations:設(shè)置JDK的安裝路徑
          Shell executable:設(shè)置window shell命令
          Ant installation:設(shè)置ant 的安裝路徑
          mave installation設(shè)置mave的安裝路徑
          cvs executable:設(shè)置cvsnt執(zhí)行進(jìn)程的路徑(cvs.exe)
          .cvspass file:設(shè)置cvsnt管理員文件的路徑(passwd文件)
          e-mail notification:設(shè)置當(dāng)發(fā)生錯(cuò)誤時(shí)發(fā)送的郵箱地址
          hudson url:就是hudson的默認(rèn)地址

          還可以配置服務(wù)器的其他幾個(gè)方面,比如向 Hudson 提供一個(gè)電子郵件服務(wù)器的位置,以便在構(gòu)建失敗時(shí)接收電子郵件。根據(jù)您的組織設(shè)置電子郵件的方式,可能需要讓系統(tǒng)管理員幫助設(shè)置這個(gè)特性。設(shè)置電子郵件并不是必需的;Hudson 還支持以 RSS 作為通知機(jī)制,對(duì)于某些人來說,這種方式比電子郵件更好。究竟選擇哪些通知機(jī)制完全取決于您。(注意,這里說的是 “哪些”,也就是說,可以同時(shí)使用多種通知機(jī)制?。?/strong>

          在 Hudson 中配置項(xiàng)目

          既然 Hudson 已經(jīng)能夠與 SCM 存儲(chǔ)庫通信了,就該配置項(xiàng)目了。這個(gè)示例所用的項(xiàng)目稱為 solar-ci。在 Hudson 主頁上單擊左上角的 New Job 鏈接。這時(shí)會(huì)看到圖 5 所示的屏幕:



          該頁面可以使我們通過hudson來管理cvs里的一個(gè)對(duì)應(yīng)的工程

          Project name:工程名稱

          Description:描述信息

          Discard build:如果選擇此項(xiàng)可以設(shè)置build記錄保存的天數(shù),或者build記錄保存的數(shù)理,或者只保存最新的build記錄,一般不需填寫

          Advance project options:可以設(shè)置hudson定時(shí)檢查cvs工程的時(shí)間間隔,還可以指定cvs工程check out到本地的工程路徑,一般不需要填寫

          Source code management:我們選擇cvs將出現(xiàn)以下參數(shù):

          Cvsroot:將寫cvs登陸字符串,格式(:protocol:user:password@host:path),例如: :pserver:cvsadmin:1@127.0.0.1:2401:/CVSNT/Repository,使用cvs必填
           

          Modules:填寫cvs倉庫下的具體工程名, 使用cvs必填

          Branch:填寫分支名稱,也可以勾選this is a tag,no a branch指定標(biāo)記名稱
           

          選擇subversion可以進(jìn)行相應(yīng)的subversion設(shè)置

          Build trigger可以設(shè)置hudson自動(dòng)執(zhí)行的一些動(dòng)作,build after others projects are built指定hudson構(gòu)建完成后需要繼續(xù)構(gòu)建的工程名

          Build periodically 根據(jù)hudson定義的語法規(guī)則來設(shè)定自動(dòng)構(gòu)建工程的時(shí)間間隔

          Post-build actions

          設(shè)置一些構(gòu)建完成后的動(dòng)作,如放郵件,打包,產(chǎn)生測試報(bào)告,產(chǎn)生java doc .

          點(diǎn)擊ok保存設(shè)置

          使用hudson
          進(jìn)入剛配置的項(xiàng)目,可以在左側(cè)build history看到歷史的build記錄,點(diǎn)擊build now 可以手動(dòng)執(zhí)行構(gòu)建動(dòng)作,完成后可以通過記錄標(biāo)記的顏色來看是否出錯(cuò),紅色有錯(cuò),藍(lán)色成功.點(diǎn)擊記錄查看詳細(xì)信息,如果有變化hudson將列出類信息


          elipse插件應(yīng)用
          eclipse updatesite:http://code.google.com/p/hudson-eclipse/
          重新打開eclipse在windows->preferences下將出現(xiàn)hudson選項(xiàng),設(shè)置默認(rèn)的hudson url保存.
          然后選擇windows->open view打開hudson view
          如果你己經(jīng)配置hudson項(xiàng)目將列出hudson的項(xiàng)目名稱,右鍵菜單可以看到所有的執(zhí)行菜單,使用還是很方便的,希望大家來完善這篇文章.
          posted on 2008-07-08 23:01 CONAN 閱讀(432) 評(píng)論(0)  編輯  收藏 所屬分類: J2EE 、項(xiàng)目管理 、JAVA
          主站蜘蛛池模板: 抚州市| 商河县| 台中市| 乌拉特后旗| 临洮县| 措勤县| 岱山县| 都兰县| 彩票| 望都县| 兴城市| 延寿县| 垦利县| 开化县| 闸北区| 铁力市| 三江| 乌恰县| 江油市| 龙州县| 蓬莱市| 石楼县| 会泽县| 西平县| 北票市| 体育| 赤壁市| 隆尧县| 隆回县| 临江市| 驻马店市| 嘉义市| 二连浩特市| 大埔县| 日土县| 汽车| 兴隆县| 维西| 旅游| 呼伦贝尔市| 永丰县|