电竞比分网-中国电竞赛事及体育赛事平台

分享

負載測試、壓力測試和性能測試的異同...

 daomucun 2009-07-17

負載測試、壓力測試和性能測試的異同 收藏

     負載測試(Load testing)、壓力測試(Stress Test,應(yīng)稱為強度測試)和性能測試,這三個概念常常引起混淆,難以區(qū)分,從而造成不正確的理解和錯誤的使用。之前,也有不少討論,比較有名的,應(yīng)歸為 Grig Gheorghiu's的兩篇博客:
     負載測試、壓力測試和性能測試的測試目的不同,但其手段和方法在一定程度上比較相似,通常會使用相同的測試環(huán)境和測試工具,而且都會監(jiān)控系統(tǒng)所占用資源的情況以及其它相應(yīng)的性能指標,這也是造成人們?nèi)菀桩a(chǎn)生概念混淆的主要原因。
     我們知道,軟件總是運行在一定的環(huán)境下,這種環(huán)境包括支撐軟件運行的軟硬件環(huán)境和影響軟件運行的外部條件。為了讓客戶使用軟件系統(tǒng)感到滿意,必須確保系統(tǒng) 運行良好,達到高安全、高可靠和高性能。其中,系統(tǒng)是否具有高性能的運行特征,不僅取決于系統(tǒng)本身的設(shè)計和程序算法,而且取決于系統(tǒng)的運行環(huán)境。系統(tǒng)的運 行環(huán)境會依賴于一些關(guān)鍵因素,例如:
  • 系統(tǒng)架構(gòu),如分布式服務(wù)器集群還是集中式主機系統(tǒng)等。
  • 硬件配置,如服務(wù)器的配置,CPU、內(nèi)存等配置越高,系統(tǒng)的性能會越好。
  • 網(wǎng)絡(luò)帶寬,隨著帶寬的提高,客戶端訪問服務(wù)器的速度會有較大的改善。
  • 支撐軟件的選定,如選定不同的數(shù)據(jù)庫管理系統(tǒng)(Oracle、MySQL等)和web應(yīng)用服務(wù)器(Tomcat、GlassFish、Jboss、WebLogic等),對應(yīng)用系統(tǒng)的性能都有影響。
  • 外部負載,同時有多少個用戶連接、用戶上載文件大小、數(shù)據(jù)庫中的記錄數(shù)等都會對系統(tǒng)的性能有影響。一般來說,系統(tǒng)負載越大,系統(tǒng)的性能會降低。
     從上面可以看出,使系統(tǒng)的性能達到一個最好的狀態(tài),不僅通過對處在特定環(huán)境下的系統(tǒng)進行測試以完成相關(guān)的驗證,而且往往要根據(jù)測試的結(jié)果,對系統(tǒng)的設(shè)計、 代碼和配置等進行調(diào)整,提高系統(tǒng)的性能。許多時候,系統(tǒng)性能的改善是測試、調(diào)整、再測試、再調(diào)整、……一個持續(xù)改進的過程,這就是我們經(jīng)常說的性能調(diào)優(yōu) (perormance tuning)。
    在了解了這樣一個背景之后,就比較容易理解為什么在性能測試中常常要談負載測試。從測試的目的出發(fā)、從用戶的需求出發(fā),就比較容易區(qū)分性能測試、負載測試 和壓力測試。性能測試是為了獲得系統(tǒng)在某種特定的條件下(包括特定的負載條件下)的性能指標數(shù)據(jù),而負載測試、壓力測試是為了發(fā)現(xiàn)軟件系統(tǒng)中所存在的問 題,包括性能瓶頸、內(nèi)存泄漏等。通過負載測試,也是為了獲得系統(tǒng)正常工作時所能承受的最大負載,這時負載測試就成為容量測試。通過壓力測試,可以知道在什 么極限情況下系統(tǒng)會崩潰、系統(tǒng)是否具有自我恢復(fù)性等,但更多的是為了確定系統(tǒng)的穩(wěn)定性。
     那么,如何給負載測試、壓力測試下個定義呢?根據(jù)上述討論,我們可以給出如下的定義:
  • 負 載測試是模擬實際軟件系統(tǒng)所承受的負載條件的系統(tǒng)負荷,通過不斷加載(如逐漸增加模擬用戶的數(shù)量)或其它加載方式來觀察不同負載下系統(tǒng)的響應(yīng)時間和數(shù)據(jù)吞 吐量、系統(tǒng)占用的資源(如CPU、內(nèi)存)等,以檢驗系統(tǒng)的行為和特性,以發(fā)現(xiàn)系統(tǒng)可能存在的性能瓶頸、內(nèi)存泄漏、不能實時同步等問題。負載測試更多地體現(xiàn) 了一種方法或一種技術(shù)。
  • 壓力測試是在強負載(大數(shù)據(jù)量、大量并發(fā)用戶等)下的測試,查看應(yīng)用系統(tǒng)在峰值使用情況下操作行為,從而有效地 發(fā)現(xiàn)系統(tǒng)的某項功能隱患、系統(tǒng)是否具有良好的容錯能力和可恢復(fù)能力。壓力測試分為高負載下的長時間(如24小時以上)的穩(wěn)定性壓力測試和極限負載情況下導(dǎo) 致系統(tǒng)崩潰的破壞性壓力測試。
     壓力測試可以被看作是負載測試的一種,即高負載下的負載測試,或者說壓力測試采用負載測試技術(shù)。通過壓力測試,可以更快地發(fā)現(xiàn)內(nèi)存泄漏問題,還可以更快地 發(fā)現(xiàn)影響系統(tǒng)穩(wěn)定性的問題。例如,在正常負載情況下,某些功能不能正常使用或系統(tǒng)出錯的概率比較低,可能一個月只出現(xiàn)一次,但在高負載(壓力測試)下,可 能一天就出現(xiàn),從而發(fā)現(xiàn)有缺陷的功能或其它系統(tǒng)問題。通過負載測試,可以證明這一點,某個電子商務(wù)網(wǎng)站的訂單提交功能,在10個并發(fā)用戶時錯誤率是零,在 50個并發(fā)用戶時錯誤率是1%,而在200個并發(fā)用戶時錯誤率是20%。
    負載測試是為了發(fā)現(xiàn)系統(tǒng)的性能問題,負載測試需要通過系統(tǒng)性能特性或行為來發(fā)現(xiàn)問題,從而為性能改進提供幫助,從這個意義看,負載測試可以看作性能測試的 一部分。但它們兩者的目的是不一樣的,負載測試是為了發(fā)現(xiàn)缺陷,而性能測試是為了獲取性能指標。因為性能測試過程中,也可以不調(diào)整負載,而是在同樣負載情 況下改變系統(tǒng)的結(jié)構(gòu)、改變算法、改變硬件配置等等來得到性能指標數(shù)據(jù),從這個意義看,負載測試可以看作是性能測試所c的一種技術(shù),即性能測試使用負載測試 的技術(shù)、使用負載測試的工具。性能測試要獲得在不同的負載情況下的性能指標數(shù)據(jù)。
    通過負載測試和壓力測試都可以獲得系統(tǒng)正常工作時的極限負載或最大容量。容量測試,自然也是采用負載測試技術(shù)來實現(xiàn),而在破壞性的壓力測試中,容量的確定可以看作是一種副產(chǎn)品——間接結(jié)果。
    綜合所述,負載測試、壓力測試和性能測試的概念可以概括如下:
  • 負載測試是通過改變系統(tǒng)負載方式、增加負載等來發(fā)現(xiàn)系統(tǒng)中所存在的性能問題。負載測試是一種測試方法,可以為性能測試、壓力測試所采用。負載測試的加載方式也有很多種,可以根據(jù)測試需要來選擇。
  • 性能測試是為獲取或驗證系統(tǒng)性能指標而進行測試。多數(shù)情況下,性能測試會在不同負載情況下進行。
  • 壓力測試通常是在高負載情況下來對系統(tǒng)的穩(wěn)定性進行測試,更有效地發(fā)現(xiàn)系統(tǒng)穩(wěn)定性的隱患和系統(tǒng)在負載峰值的條件下功能隱患等。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多