posts - 56, comments - 77, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          ©Copyright 2008 Julian Simpson. All rights reserved.

          英文原文:   Scaling up

          I was an Infrastructure Specialist at ThoughtWorks.  In my role I make sure that we are building our software so it can successfully be deployed to production.  In this series of blog posts I hope to pass on my top ten tips for using CruiseControl Enterprise effectively.  I'm writing these with the developers or systems administrators in mind: the people who most often manage CruiseControl.  However, I hope that anybody who is interested in Continuous Integration will get something from these articles.

          # 6:  Scaling up

          第 一件要做的事就是確保你可以同時構(gòu)建你的多個項目. CruiseControl使用Java線程來管理構(gòu)建和項目. 每個項目都有自己的項目線程. 而至少有一個構(gòu)建線程來真正的運行一次構(gòu)建.  實際上有一個構(gòu)建隊列, 來調(diào)度從項目線程到發(fā)到構(gòu)建線程的請求. 你要給CruiseControl足夠的構(gòu)建線程來運行: 缺省情況下只有一個構(gòu)建線程. 它的影響就是如果你配置了 5 個項目, 你也只能一次構(gòu)建一個. 這也可以接受, 如果你只有一臺很弱的構(gòu)建服務(wù)器, 或者項目之間不能和平共處.

          另一方面, 如果你有強大的計算能力可以使用, 你就可以從額外的構(gòu)建線程中得到提速. 正確的線程數(shù)量設(shè)置會隨著時間而變化; 不要不情愿去做性能管理來找到你的服務(wù)器的最優(yōu)的設(shè)置.

          <cruisecontrol>

           
          <system>
            
          <configuration>
                
          <threads count="2" />
            
          </configuration>
           
          </system>

           
          <!-- rest of config file suppressed -->

          </cruisecontrol>

          Jeffrey Frederick 則明智的指出設(shè)置多于項目個數(shù)的構(gòu)建線程數(shù)是沒有意義的.


          在 調(diào)優(yōu)你的持續(xù)集成服務(wù)時, 還有大量的其它因素可以考慮: 你的版本控制系統(tǒng)的速度, 你在哪里存儲你的構(gòu)建產(chǎn)物, 日志, 等等. 今天我要提到的一個因素是硬盤帶寬. 編譯軟件是一個很耗硬盤的過程. 即使構(gòu)建已經(jīng)完成了編譯Java代碼和打包jar包等操作, CruiseControl還得寫日志文件. 所有這些事情很容易就會讓單個硬盤滿負(fù)荷運轉(zhuǎn). 理想情況下你想確保你的機器能夠一次構(gòu)建多個項目.

          在 我很早期的一個ThoughtWorks項目中, 我們的團隊運行了兩個CruiseControl服務(wù)器, 顯然是因為最初的那個Solaris服務(wù)器太慢了. 對我來說這看起來不對勁. 于是我深入的看了一下. 依靠我的系統(tǒng)管理員背景, 我發(fā)現(xiàn)了某個硬盤100%的忙于運行操作系統(tǒng), CruiseControl和構(gòu)建. 我把工作負(fù)載分布到系統(tǒng)中的四個硬盤上, 然后那臺機器就能管理多得多的項目了.

          在我后續(xù)的項目中, 這個模式不斷的重復(fù). 以我的經(jīng)驗, 沒有多少CI服務(wù)器是因為處理器過載而受到限制. 不幸的是, 一旦系統(tǒng)啟動并開始運行, 矯正磁盤問題通常會很痛苦. 在調(diào)優(yōu)和人們開始抱怨緩慢的構(gòu)建之前, 定購大量的快速的硬盤驅(qū)動器并祝自己好運.


          實 現(xiàn)這個模式的方法是使用CruiseControl的配置文件. <log>元素用來告訴CruiseControl把日志文件寫到哪. 缺省情況下它是CruiseControl安裝目錄下的一個子目錄. 如果你修改了<log>元素的"dir"屬性, 你就能夠確保日志文件可以寫到?jīng)]有運行CruiseControl的硬盤上. 如果你使用 Ant 來構(gòu)建你的代碼, 你可以使用配置文件中<ant>元素的 "antWorkingDir" 屬性來保證你的項目在另外一個硬盤上構(gòu)建.

          我 無法為此給出一個很好的例子, 每個CruiseControl的實例之間太不一樣了. Buildx是一個使多個安裝更一致的嘗試. 如果你看一下各個部分在硬盤上的布局方式, 你就會發(fā)現(xiàn)CruiseControl的安裝在/usr/share/cruisecontrol, 但是projects和logs安裝在/var/spool/cruisecontrol: 我們這么做的原因是這樣的話你就能 mount /var 目錄到另外一塊硬盤, 如果系統(tǒng)開始變得繁忙. 如果你想知道更多的話隨時告訴我.

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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 榆中县| 旬阳县| 南丹县| 酉阳| 乡宁县| 象州县| 庆云县| 法库县| 抚顺市| 鹿邑县| 株洲县| 上思县| 措美县| 陈巴尔虎旗| 泰来县| 平湖市| 曲松县| 府谷县| 丹寨县| 黎平县| 乐清市| 辽宁省| 买车| 西安市| 陆川县| 大城县| 墨脱县| 德州市| 博客| 寿光市| 天镇县| 东阳市| 丹巴县| 盖州市| 阿拉善左旗| 西贡区| 阿克陶县| 汕尾市| 安岳县| 方正县| 祁东县|