一.什么是持續(xù)集成
持續(xù)集成的核心概念
CI過程會經(jīng)常構(gòu)建軟件 組件;在許多情況下,每當源代碼 存儲庫(比如 Subversion或ClearCase)中的代碼發(fā)生變化時,都要構(gòu)建軟件組件。CI的好處是:經(jīng)常構(gòu)建軟件可以確保盡早遇到問題(比如代碼缺陷),避免問題在軟件開發(fā)周期晚期變復(fù)雜時才被發(fā)現(xiàn)。
工具 與過程
盡管 CI 實際上是一個過程,但是持續(xù)集成 這個詞常常與一個或多個工具相關(guān)聯(lián)。在本教程中,講解如何安裝、配置和使用 Hudson 作為 CI 服務(wù)器,但是要記住,CI遠不只是個工具。實際上,使用的工具可能是 CI 比較次要的方面,因為CI工具所做的僅僅是在代碼存儲庫中探測到修改時運行構(gòu)建。構(gòu)建過程本身比用來運行它的工具重要得多。
開始使用 CI
開始使用 CI 需要三個組件:
我們來詳細討論這些組件。
自動的構(gòu)建
CI過程會經(jīng)常集成軟件,這需要通過構(gòu)建來完成。在 Java 環(huán)境中,Ant 是常用的構(gòu)建平臺。可以使用 Ant可靠地自動執(zhí)行編譯、測試等任務(wù),甚至可以執(zhí)行軟件檢查和部署。在掌握了 CI 的所有組件之后,您會發(fā)現(xiàn)構(gòu)建策略是成功的 CI過程最重要的方面。如果缺少適當?shù)臉?gòu)建過程,CI就難以發(fā)揮作用。
源代碼 管理
為了讓 CI 正確地發(fā)揮作用,需要一個源代碼管理(SCM)系統(tǒng) 或存儲庫,比如 Subversion 或 CVS。CI 服務(wù)器向SCM存儲庫查詢代碼修改。在找到修改時,CI服務(wù)器執(zhí)行簽出(即更新本地沙箱)并執(zhí)行構(gòu)建。除了執(zhí)行得更頻繁之外,構(gòu)建過程與在本地環(huán)境中執(zhí)行的構(gòu)建相同。
CI 服務(wù)器
對于成功的 CI 過程,需要用一個自動的過程監(jiān)視 SCM 存儲庫并在探測到修改時運行構(gòu)建,這也非常重要。對于 Java 平臺,有許多可用的CI服務(wù)器,包括開放源碼軟件和商業(yè)產(chǎn)品。它們的基本配置都很相似,適合監(jiān)視特定的 SCM 并在探測到修改時運行構(gòu)建。所有 CI服務(wù)器都有自己的優(yōu)缺點。Hudson尤其讓人感興趣,因為它容易配置而且具有強大的插件,這些插件可以顯示測試結(jié)果趨勢等信息。
二.Hudson 簡介
Hudson 是一種革命性的開放源碼 CI 服務(wù)器,它從以前的 CI服務(wù)器吸取了許多經(jīng)驗 教訓(xùn)。Hudson最吸引人的特性之一是它很容易配置:很難找到更容易設(shè)置的 CI 服務(wù)器,也很難找到開箱即用特性如此豐富的CI 服務(wù)器。Hudson容易使用的第二個原因是它具有強大的插件框架 ,所以很容易添加特性。例如,一個 Hudson 插件可以隨時間的推移跟蹤FindBugs和代碼覆蓋。它還可以報告測試結(jié)果的趨勢(來自 JUnit 或 TestNG)以及構(gòu)建結(jié)果和對應(yīng)的執(zhí)行時間。
Hudson 需要運行 Java 5。如果需要使用 Hudson 附帶的嵌入式 容器(Winstone)之外的其他容器,那么只需使用一種 Servlet2.4 容器。對于大多數(shù)情況,Winstone 就足夠了。
三.Hudson使用
CI 過程的最后一個方面是 CI服務(wù)器本身。CI服務(wù)器在整個開發(fā)過程中的主要作用是控制者:當服務(wù)器在代碼存儲庫中探測到修改時,它將運行構(gòu)建的任務(wù)委托給構(gòu)建過程本身。如果構(gòu)建失敗了,那么CI服務(wù)器將通知相關(guān)方面,然后繼續(xù)監(jiān)視存儲庫。它的角色看起來是被動的;但是,它是快速反映問題的關(guān)鍵。
安裝 Hudson
使用 Hudson 的主要好處之一是它的設(shè)置很簡單。在最簡單的情況下,Hudson 只需要兩個步驟:
這樣就可以了。因為下載的是一個 WAR 文件,所以如果愿意,可以將它部署在 Tomcat 或 JBoss 等容器中。這完全由您自己決定。當然,Hudson假設(shè)在安裝它的機器上運行著 Java 5,而且如果定義了JAVA_HOME 環(huán)境變量,Hudson 就會使用它。(正如前面提到的,Hudson 需要 Java5。)
在安裝并運行 Hudson 之后(將 WAR 文件部署到 servlet 容器或從命令行執(zhí)行java -jar hudson.war),啟動瀏覽器并訪問默認安裝位置。如果通過命令行運行 Hudson 而且您在本地機器上,那么可以訪問http://localhost:8080/ 。
如果一切正常(實際上不太可能出問題),應(yīng)該會看到圖 2 所示的 Hudson 啟動頁面。
配置 Hudson
如果訪問 Hudson 主頁的本地實例并單擊左上角的 Manage Hudson 鏈接,應(yīng)該會看到圖 3 所示的可配置選項列表。
圖 3. 配置 Hudson 非常容易
參數(shù)說明:
system.message 填寫一些說明信息
Quiet period:hudson定時構(gòu)建工程的時間(秒)
Enable security:設(shè)置hudson登陸的規(guī)則(默認為匿名登陸)
TCP port for JNLP slave agents:不了解JNLP不敢胡寫總之就是三種方式:固定(fixed) 隨機(Radom)不使用(disabled),使用固定時可以填入JNLP信息
security realm:可以使用中間件容器,數(shù)據(jù)庫,LDAP來驗證安全,具體怎樣用法沒用過,以后會有更新,研究中.
authorized:可以設(shè)置身份的驗證方法:系統(tǒng)用戶,匿名用戶,自定義用戶,還有繼承用戶(此處也在研究中,建議使用匿名用戶)
JDK installations:設(shè)置JDK的安裝路徑
Shell executable:設(shè)置window shell命令
Ant installation:設(shè)置ant 的安裝路徑
mave installation設(shè)置mave的安裝路徑
cvs executable:設(shè)置cvsnt執(zhí)行進程的路徑(cvs.exe)
.cvspass file:設(shè)置cvsnt管理員文件的路徑(passwd文件)
e-mail notification:設(shè)置當發(fā)生錯誤時發(fā)送的郵箱地址
hudson url:就是hudson的默認地址
還可以配置服務(wù)器的其他幾個方面,比如向 Hudson提供一個電子郵件服務(wù)器的位置,以便在構(gòu)建失敗時接收電子郵件。根據(jù)您的組織設(shè)置電子郵件的方式,可能需要讓系統(tǒng)管理員幫助設(shè)置這個特性。設(shè)置電子郵件并不是必需的;Hudson還支持以 RSS 作為通知機制,對于某些人來說,這種方式比電子郵件更好。究竟選擇哪些通知機制完全取決于您。(注意,這里說的是“哪些”,也就是說,可以同時使用多種通知機制?。?/p>
在 Hudson 中配置項目
既然 Hudson 已經(jīng)能夠與 SCM 存儲庫通信了,就該配置項目了。這個示例所用的項目稱為 solar-ci。在 Hudson 主頁上單擊左上角的New Job 鏈接。這時會看到圖 5 所示的屏幕:
該頁面可以使我們通過hudson來管理cvs里的一個對應(yīng)的工程
Project name:工程名稱
Description:描述信息
Discardbuild:如果選擇此項可以設(shè)置build記錄保存的天數(shù),或者build記錄保存的數(shù)理,或者只保存最新的build記錄,一般不需填寫
Advance project options:可以設(shè)置hudson定時檢查cvs工程的時間間隔,還可以指定cvs工程checkout到本地的工程路徑,一般不需要填寫
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 abranch指定標記名稱
選擇subversion可以進行相應(yīng)的subversion設(shè)置
Build trigger可以設(shè)置hudson自動執(zhí)行的一些動作,build after others projects arebuilt指定hudson構(gòu)建完成后需要繼續(xù)構(gòu)建的工程名
Build periodically 根據(jù)hudson定義的語法規(guī)則來設(shè)定自動構(gòu)建工程的時間間隔
Post-build actions
設(shè)置一些構(gòu)建完成后的動作,如放郵件,打包,產(chǎn)生測試報告,產(chǎn)生java doc 等.
點擊ok保存設(shè)置
使用hudson
進入剛配置的項目,可以在左側(cè)build history看到歷史的build記錄,點擊build now可以手動執(zhí)行構(gòu)建動作,完成后可以通過記錄標記的顏色來看是否出錯,紅色有錯,藍色成功.點擊記錄查看詳細信息,如果有變化hudson將列出類信息
elipse插件應(yīng)用
eclipse updatesite:http://code.google.com/p/hudson-eclipse/
重新打開eclipse在windows->preferences下將出現(xiàn)hudson選項,設(shè)置默認的hudson url保存.
然后選擇windows->open view打開hudson view
如果你己經(jīng)配置hudson項目將列出hudson的項目名稱,右鍵菜單可以看到所有的執(zhí)行菜單,使用還是很方便的,希望大家來完善這篇文章.
聯(lián)系客服