小程人生

          統(tǒng)計(jì)

          留言簿(2)

          閱讀排行榜

          評(píng)論排行榜

          持續(xù)集成工具h(yuǎn)udson

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

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

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

          工具與過(guò)程

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

          開(kāi)始使用 CI

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

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

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

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

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

          源代碼管理

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

          CI 服務(wù)器

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

          二.Hudson 簡(jiǎn)介

          Hudson 是一種革命性的開(kāi)放源碼 CI 服務(wù)器,它從以前的 CI 服務(wù)器吸取了許多經(jīng)驗(yàn)教訓(xùn)。Hudson 最吸引人的特性之一是它很容易配置:很難找到更容易設(shè)置的 CI 服務(wù)器,也很難找到開(kāi)箱即用特性如此豐富的 CI 服務(wù)器。Hudson 容易使用的第二個(gè)原因是它具有強(qiáng)大的插件框架,所以很容易添加特性。例如,一個(gè) Hudson 插件可以隨時(shí)間的推移跟蹤 FindBugs 和代碼覆蓋。它還可以報(bào)告測(cè)試結(jié)果的趨勢(shì)(來(lái)自 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 過(guò)程的最后一個(gè)方面是 CI 服務(wù)器本身。CI 服務(wù)器在整個(gè)開(kāi)發(fā)過(guò)程中的主要作用是控制者:當(dāng)服務(wù)器在代碼存儲(chǔ)庫(kù)中探測(cè)到修改時(shí),它將運(yùn)行構(gòu)建的任務(wù)委托給構(gòu)建過(guò)程本身。如果構(gòu)建失敗了,那么 CI 服務(wù)器將通知相關(guān)方面,然后繼續(xù)監(jiān)視存儲(chǔ)庫(kù)。它的角色看起來(lái)是被動(dòng)的;但是,它是快速反映問(wèn)題的關(guān)鍵。

          安裝 Hudson

          使用 Hudson 的主要好處之一是它的設(shè)置很簡(jiǎn)單。在最簡(jiǎn)單的情況下,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)瀏覽器并訪問(wèn)默認(rèn)安裝位置。如果通過(guò)命令行運(yùn)行 Hudson 而且您在本地機(jī)器上,那么可以訪問(wèn) http://localhost:8080/。


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

          配置 Hudson

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

          圖 3. 配置 Hudson 非常容易

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

          security realm:可以使用中間件容器,數(shù)據(jù)庫(kù),LDAP來(lái)驗(yàn)證安全,具體怎樣用法沒(méi)用過(guò),以后會(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ì)于某些人來(lái)說(shuō),這種方式比電子郵件更好。究竟選擇哪些通知機(jī)制完全取決于您。(注意,這里說(shuō)的是 “哪些”,也就是說(shuō),可以同時(shí)使用多種通知機(jī)制?。?/strong>

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

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



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

          Project name:工程名稱(chēng)

          Description:描述信息

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

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

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

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

          Modules:填寫(xiě)cvs倉(cāng)庫(kù)下的具體工程名, 使用cvs必填

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

          選擇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定義的語(yǔ)法規(guī)則來(lái)設(shè)定自動(dòng)構(gòu)建工程的時(shí)間間隔

          Post-build actions

          設(shè)置一些構(gòu)建完成后的動(dòng)作,如放郵件,打包,產(chǎn)生測(cè)試報(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)作,完成后可以通過(guò)記錄標(biāo)記的顏色來(lái)看是否出錯(cuò),紅色有錯(cuò),藍(lán)色成功.點(diǎn)擊記錄查看詳細(xì)信息,如果有變化hudson將列出類(lèi)信息


          elipse插件應(yīng)用
          eclipse updatesite:http://code.google.com/p/hudson-eclipse/
          重新打開(kāi)eclipse在windows->preferences下將出現(xiàn)hudson選項(xiàng),設(shè)置默認(rèn)的hudson url保存.
          然后選擇windows->open view打開(kāi)hudson view
          如果你己經(jīng)配置hudson項(xiàng)目將列出hudson的項(xiàng)目名稱(chēng),右鍵菜單可以看到所有的執(zhí)行菜單,使用還是很方便的,希望大家來(lái)完善這篇文章.

          posted on 2008-07-08 13:08 小程人生 閱讀(23746) 評(píng)論(4)  編輯  收藏

          評(píng)論

          # re: 持續(xù)集成工具h(yuǎn)udson[未登錄](méi) 2008-07-08 20:08 javaread.com

          hudson算很不錯(cuò)的CI工具了,發(fā)展很快。  回復(fù)  更多評(píng)論   

          # re: 持續(xù)集成工具h(yuǎn)udson[未登錄](méi) 2008-07-10 14:45 alfred

          你的那篇hibernate繼承實(shí)現(xiàn)的文章哪去了  回復(fù)  更多評(píng)論   

          # re: 持續(xù)集成工具h(yuǎn)udson[未登錄](méi) 2008-07-10 17:02 小程人生

          @alfred
          我過(guò)幾天補(bǔ)上,被我不小心刪掉了  回復(fù)  更多評(píng)論   

          # re: 持續(xù)集成工具h(yuǎn)udson 2008-07-11 09:58 小程人生

          @alfred
          補(bǔ)上了,對(duì)不起呀  回復(fù)  更多評(píng)論   


          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 江陵县| 兴隆县| 苏尼特左旗| 黄冈市| 保康县| 西城区| 弥渡县| 玉山县| 阿图什市| 建水县| 依安县| 宁海县| 东兴市| 延安市| 台中县| 鲜城| 佛坪县| 南江县| 罗源县| 周口市| 鸡东县| 元朗区| 德州市| 克拉玛依市| 柳林县| 汉中市| 文水县| 简阳市| 辽宁省| 呼图壁县| 濮阳县| 宁蒗| 突泉县| 芜湖县| 连平县| 清镇市| 民丰县| 和田县| 博客| 鹿泉市| 金湖县|