什么是性能測試,就是豬八戒背媳婦?
不少前輩總結(jié)過,性能測試是在時間和空間上尋找最佳結(jié)合點。馬兒跑得快是指時間,不吃草是指空間。性能測試則是尋找時間和空間之間的一個平衡點。
本文引用地址:http://m.butianyuan.cn/article/201612/333327.htm上述為最樸素和廣義的性能測試。
性能測試的觀點
性能測試有如下幾個觀點可以進(jìn)行關(guān)注:
用戶的觀點:用戶的觀點很簡單,系統(tǒng)快而穩(wěn)定!所以如果從用戶觀點進(jìn)行性能測試的話,那么性能測試的最終效果表現(xiàn)為提高用戶體驗。大部分門戶網(wǎng)站的性能測試就是從用戶的觀點來編寫測試用例和腳本的。
系統(tǒng)的觀點:系統(tǒng)觀點也不難。在已有得性能硬件軟件條件下,進(jìn)行系統(tǒng)測試從而獲取系統(tǒng)的短板,短板可能是硬件瓶頸,也可能是軟件的缺陷。系統(tǒng)觀點的最終測試效果表現(xiàn)為優(yōu)化系統(tǒng)軟硬件,消除系統(tǒng)的顯式瓶頸。
開發(fā)的觀點:開發(fā)的觀點與系統(tǒng)觀點差不多,但是開發(fā)觀點對軟件關(guān)注得更為投入。以開發(fā)觀點進(jìn)行性能測試,則性能測試的介入時間會比以上兩種觀點都要來得早。比如系統(tǒng)數(shù)據(jù)庫設(shè)計完畢之后,就可以立即利用性能測試來測試數(shù)據(jù)庫設(shè)計上的瓶頸,而不像上述兩種測試觀點一樣,必須系統(tǒng)功能測試穩(wěn)定之后方可進(jìn)行。
綜上所述,從用戶的觀點去進(jìn)行性能測試是滿足用戶需求的最好手段;而從系統(tǒng)角度去進(jìn)行性能測試則可以確定系統(tǒng)的性能指標(biāo)。而從開發(fā)的觀點去進(jìn)行性能測試則對開發(fā)過程很有幫助,也會降低后續(xù)出現(xiàn)性能瓶頸的風(fēng)險。
性能測試的幾種常見方法
負(fù)載測試:負(fù)載測試是用戶觀點的測試行為。簡單說來就是負(fù)載測試就是讓系統(tǒng)在一定得負(fù)載壓力下進(jìn)行正常的工作,觀察系統(tǒng)的表現(xiàn)能否滿足用戶的需求。
用戶的需求從何而來?需求分析——特指性能測試的需求分析。由此看來需求分析是相當(dāng)重要的。
負(fù)載測試是站在用戶的角度去觀察在一定條件下軟件系統(tǒng)的性能表現(xiàn)。
負(fù)載測試的預(yù)期結(jié)果是用戶的性能需求得到滿足。此指標(biāo)一般體現(xiàn)為響應(yīng)時間、交易容量、并發(fā)容量、資源使用率等。
負(fù)載測試也是最常用的性能測試方法,因此也有不少人將負(fù)載測試混淆為性能測試。
壓力測試:壓力測試的關(guān)鍵字就是“極端”。通過對系統(tǒng)的極端加壓,從而觀察系統(tǒng)的所表現(xiàn)出來性能問題。再對此性能問題進(jìn)行分析,從而達(dá)到系統(tǒng)優(yōu)化的目的。所以壓力測試就是一定要讓系統(tǒng)出問題,如果系統(tǒng)沒有出問題,那么壓力測試的手段和方法就肯定存在問題。
并發(fā)測試:驗證系統(tǒng)的并發(fā)能力。通過一定的并發(fā)量觀察系統(tǒng)在該并發(fā)量的情況下所表現(xiàn)出來的行為特征,確定系統(tǒng)是否滿足設(shè)計的并發(fā)需要。并發(fā)測試是系統(tǒng)觀點的測試行為。
基準(zhǔn)測試:顧名思義,基準(zhǔn)測試要有一個基準(zhǔn)點,也就是說供比較基點。當(dāng)軟件系統(tǒng)中增加一個新的模塊的時候,需要做基準(zhǔn)測試,以判斷新模塊對整個軟件系統(tǒng)的性能影響。按照基準(zhǔn)測試的方法,需要打開/關(guān)閉新模塊至少各做一次測試。關(guān)閉模塊之前的系統(tǒng)各個性能指標(biāo)記下來作為基準(zhǔn)(Benchmark),然后與打開模塊狀態(tài)下的系統(tǒng)性能指標(biāo)作比較,以判斷模塊對系統(tǒng)性能的影響。
穩(wěn)定性測試:很簡單,長時間進(jìn)行負(fù)載測試,從而觀察系統(tǒng)的穩(wěn)定性。
可恢復(fù)性測試:測試系統(tǒng)能否快速地從錯誤狀態(tài)中恢復(fù)到正常狀態(tài)。比如,在一個配有負(fù)載均衡的系統(tǒng)中,主機(jī)承受了壓力無法正常工作后,備份機(jī)是否能夠快速地接管負(fù)載??苫謴?fù)測試通常結(jié)合壓力測試一起來做。
好吧,如果以上概念仍然過于“神乎其技”讓人如同滿文過生日一般如墜云里霧里,下面我將會以打比方的方式讓大家更好的理解上述內(nèi)容。
《西游記》中有一場景叫做:“豬八戒背媳婦”,下面我們就以這個來打比方向大家描述幾種性能測試方法的異同點。
我們將豬八戒同志作為性能測試的被測試對象。
負(fù)載測試:豬同志身上背著的高小姐可以被視為加在“豬八戒人豬混合系統(tǒng)”上的負(fù)載。當(dāng)然了,豬八戒身強(qiáng)體壯,背個高小姐應(yīng)該是問題不大的。負(fù)載測試就是讓豬八戒背著高小姐走路(這里的走路就是一定得系統(tǒng)行為,通常這種系統(tǒng)行為通過腳本來進(jìn)行模擬),我們觀察豬八戒的生理和心理指標(biāo)是否存在異常從而斷定“豬八戒人豬混合系統(tǒng)”的瓶頸所在。如果豬八戒背著背著腰酸背疼腿抽筋,那么豬無能同志可能是缺鈣了,需要補(bǔ)鈣;如果他背著背著頭暈眼花四肢麻木,那么豬同志應(yīng)該是脂肪肝、酒精肝三高患者的杰出代表,這就證明豬八戒需要減肥了。如果豬八戒背著小媳婦身輕如燕、健步如飛,那么我們可以判斷豬八戒同志是個好同志,“豬八戒人豬混合系統(tǒng)”是個好系統(tǒng)。當(dāng)然,這只是在沒有測試標(biāo)準(zhǔn)的衡量基礎(chǔ)上得到的結(jié)論,為了更進(jìn)一步的測試“豬八戒人豬混合系統(tǒng)”,我們需要給這個系統(tǒng)一些指標(biāo),這個指標(biāo)舉例如下:背著體重為45公斤的高小姐走上一段山路十八彎總長為10公里的羊腸小道,在此過程中豬八戒同志的平均時速不能低于8km/h,其心跳不能快于60次/秒。好吧,再進(jìn)行一次測試,我們發(fā)現(xiàn)在測試過程中豬八戒同志依然健步如飛,身輕如燕,但是其心跳卻高于60次/秒。于是在豬八戒同志心跳高于60次/秒的那一刻,我們可以停止測試,幫豬八戒同志找出瓶頸,待此瓶頸問題被解決后,我們再對其進(jìn)行測試。當(dāng)然,如果豬八戒一背上高小姐就顯得異常吃力,舉步維艱,那么我們可以認(rèn)為高小姐應(yīng)該減肥了(負(fù)載過大),我們應(yīng)該讓高小姐節(jié)食一段時間,體重達(dá)到正常標(biāo)準(zhǔn)后再進(jìn)行測試。以上就是負(fù)載測試的一個通俗例子。
壓力測試:還是豬八戒同志背媳婦。我們發(fā)現(xiàn)他一次背一個媳婦異常輕松,于是乎我們必須加大負(fù)載,讓豬八戒在極端的情況下進(jìn)行背媳婦活動。我們可以讓豬八戒同志一次背10個媳婦,當(dāng)然這并不符合一夫一妻制,因此我們選擇讓豬八戒同志來背孫悟空同學(xué)。孫同學(xué)是石頭里蹦出來的,所以密度大,質(zhì)量大,符合極端負(fù)載的標(biāo)準(zhǔn)。
測試開始了,豬同志背上孫同學(xué)立即大汗淋漓、哭爹喊娘。好了,極端負(fù)載的條件達(dá)到。我們可以觀察豬八戒的表現(xiàn)以確定豬八戒同志全身最薄弱的部位了。如果我們發(fā)現(xiàn)豬八戒同志腹部力量不足從而導(dǎo)致背孫同學(xué)極度吃力,那么我們可以讓豬八戒去練腹肌,讓他的腹部力量得到增強(qiáng)。這樣我們也找到了系統(tǒng)的瓶頸,對系統(tǒng)進(jìn)行了優(yōu)化。
如果豬八戒背上孫悟空依然輕輕松松,神情自若,那么我們可以猜測豬八戒背的孫同學(xué)不是孫悟空而是孫尚香。于是我們可以選擇更大的負(fù)載進(jìn)行測試。
壓力測試一定要測出來問題,否則我們有理由認(rèn)為壓力負(fù)載過小,不符合測試要求。
并發(fā)測試:主要是測試豬八戒一次能背幾個媳婦。如果“豬八戒人豬混合系統(tǒng)”的設(shè)計目標(biāo)是“一次至少背上三到四個高小姐”的話,我們就有尺度來衡量豬八戒的表現(xiàn)是否達(dá)標(biāo)。
基準(zhǔn)測試:如果豬八戒同志在被高小姐的時候沒有服用任何的違禁藥品,那么我們可以將此次的測試結(jié)果作為一個基點,然后讓豬八戒同志喝點紅?;蛘呤菍W(xué)習(xí)滿文**同學(xué)嗑點小藥,然后進(jìn)行同樣的負(fù)載測試,查看****或者是喝紅牛對豬八戒背高小姐這個行為是否產(chǎn)生了利弊影響。這里的****可以值得是軟件更換了一種新算法,也可以理解系統(tǒng)更換了新的中間件。當(dāng)然我們也可以不讓豬八戒同志背高小姐,而換成是讓孫悟空同學(xué)背高小姐,觀察這兩次測試的測試結(jié)果,從而確定究竟那一種系統(tǒng)更能勝任“背高小姐”這個重任。
穩(wěn)定性測試:讓豬八戒背高小姐背上七七四十九天,觀察豬同學(xué)的表現(xiàn)。若“豬八戒人豬混合系統(tǒng)”的設(shè)計要求為至少能連續(xù)背高小姐走上49天,而實際豬八戒只走了36天的話,我們可以認(rèn)為“豬八戒人豬混合系統(tǒng)”不達(dá)標(biāo),需要優(yōu)化。
可恢復(fù)性測試:先讓豬八戒背孫悟空同志走上半天,此時豬八戒已經(jīng)累得接近崩潰,然后再讓豬八戒背上高小姐,查看豬八戒是否能從疲勞中恢復(fù),從而擔(dān)當(dāng)起背高小姐的重任。
評論