第一篇:(總結(jié))Web性能壓力測(cè)試工具之ApacheBench(ab)詳解
PS:網(wǎng)站性能壓力測(cè)試是性能調(diào)優(yōu)過(guò)程中必不可少的一環(huán)。只有讓服務(wù)器處在高壓情況下才能真正體現(xiàn)出各種設(shè)置所暴露的問(wèn)題。Apache中有個(gè)自帶的,名為ab的程序,可以對(duì)Apache或其它類(lèi)型的服務(wù)器進(jìn)行網(wǎng)站訪(fǎng)問(wèn)壓力測(cè)試。ApacheBench命令原理:
ab命令會(huì)創(chuàng)建很多的并發(fā)訪(fǎng)問(wèn)線(xiàn)程,模擬多個(gè)訪(fǎng)問(wèn)者同時(shí)對(duì)某一URL地址進(jìn)行訪(fǎng)問(wèn)。它的測(cè)試目標(biāo)是基于URL的,因此,既可以用來(lái)測(cè)試Apache的負(fù)載壓力,也可以測(cè)試nginx、lighthttp、tomcat、IIS等其它Web服務(wù)器的壓力。ab命令對(duì)發(fā)出負(fù)載的計(jì)算機(jī)要求很低,既不會(huì)占用很高CPU,也不會(huì)占用很多內(nèi)存,但卻會(huì)給目標(biāo)服務(wù)器造成巨大的負(fù)載,其原理類(lèi)似CC攻擊。自己測(cè)試使用也須注意,否則一次上太多的負(fù)載,可能造成目標(biāo)服務(wù)器因資源耗完,嚴(yán)重時(shí)甚至導(dǎo)致死機(jī)。ApacheBench參數(shù)說(shuō)明
格式:ab [options] [http://]hostname[:port]/path 參數(shù)說(shuō)明:
-n requests Number of requests to perform //在測(cè)試會(huì)話(huà)中所執(zhí)行的請(qǐng)求個(gè)數(shù)(本次測(cè)試總共要訪(fǎng)問(wèn)頁(yè)面的次數(shù))。默認(rèn)時(shí),僅執(zhí)行一個(gè)請(qǐng)求。
-c concurrency Number of multiple requests to make //一次產(chǎn)生的請(qǐng)求個(gè)數(shù)(并發(fā)數(shù))。默認(rèn)是一次一個(gè)。-t timelimit Seconds to max.wait for responses //測(cè)試所進(jìn)行的最大秒數(shù)。其內(nèi)部隱含值是-n 50000。它可以使對(duì)服務(wù)器的測(cè)試限制在一個(gè)固定的總時(shí)間以?xún)?nèi)。默認(rèn)時(shí),沒(méi)有時(shí)間限制。-p postfile File containing data to POST //包含了需要POST的數(shù)據(jù)的文件,文件格式如“p1=1&p2=2”.使用方法是-p 111.txt。(配合-T)
-T content-type Content-type header for POSTing //POST數(shù)據(jù)所使用的Content-type頭信息,如-T “application/x-transferred: 203479961 bytes #整個(gè)過(guò)程中的HTML內(nèi)容傳輸量
Requests per second: 337.67 [#/sec](mean)#最重要的指標(biāo)之一,相當(dāng)于LR中的每秒事務(wù)數(shù),后面括號(hào)中的mean表示這是一個(gè)平均值
Time per request: 2961.449 [ms](mean)#最重要的指標(biāo)之二,相當(dāng)于LR中的平均事務(wù)響應(yīng)時(shí)間,后面括號(hào)中的mean表示這是一個(gè)平均值
Time per request: 2.961 [ms](mean, across all concurrent requests)#每個(gè)連接請(qǐng)求實(shí)際運(yùn)行時(shí)間的平均值
Transfer rate: 16866.07 [Kbytes/sec] received #平均每秒網(wǎng)絡(luò)上的流量,可以幫助排除是否存在網(wǎng)絡(luò)流量過(guò)大導(dǎo)致響應(yīng)時(shí)間延長(zhǎng)的問(wèn)題
Connection Times(ms)min mean[+/-sd] median max Connect: 0 483 1773.5 11 9052 Processing: 2 556 1459.1 255 11763 Waiting: 1 515 1459.8 220 11756 Total: 139 1039 2296.6 275 11843 #網(wǎng)絡(luò)上消耗的時(shí)間的分解,各項(xiàng)數(shù)據(jù)的具體算法還不是很清楚 Percentage of the requests served within a certain time(ms)50% 275 66% 298 75% 328 80% 373 90% 3260 95% 9075 98% 9267 99% 11713 100% 11843(longest request)#整個(gè)場(chǎng)景中所有請(qǐng)求的響應(yīng)情況。在場(chǎng)景中每個(gè)請(qǐng)求都有一個(gè)響應(yīng)時(shí)間,其中50%的用戶(hù)響應(yīng)時(shí)間小于275毫秒,66%的用戶(hù)響應(yīng)時(shí)間小于298毫秒,最大的響應(yīng)時(shí)間小于11843毫秒。對(duì)于并發(fā)請(qǐng)求,cpu實(shí)際上并不是同時(shí)處理的,而是按照每個(gè)請(qǐng)求獲得的時(shí)間片逐個(gè)輪轉(zhuǎn)處理的,所以基本上第一個(gè)Time per request時(shí)間約等于第二個(gè)Time per request時(shí)間乘以并發(fā)請(qǐng)求數(shù)。總結(jié):在遠(yuǎn)程對(duì)web服務(wù)器進(jìn)行壓力測(cè)試,往往效果不理想(因?yàn)榫W(wǎng)絡(luò)延時(shí)過(guò)大),建議使用內(nèi)網(wǎng)的另一臺(tái)或者多臺(tái)服務(wù)器通過(guò)內(nèi)網(wǎng)進(jìn)行測(cè)試,這樣得出的數(shù)據(jù),準(zhǔn)確度會(huì)高很多。如果只有單獨(dú)的一臺(tái)服務(wù)器,可以直接本地測(cè)試,比遠(yuǎn)程測(cè)試效果要準(zhǔn)確。
? Apache下載
? 進(jìn)入apache服務(wù)器官網(wǎng)http://httpd.apache.org/,這里我們以下載穩(wěn)定版的
httpd 2.2.29為例,點(diǎn)擊download。? 2 由于官方網(wǎng)頁(yè)改版,以前的方式可能五法進(jìn)行下載,為了不浪費(fèi)大家的時(shí)間,特此修正2015-01-24 第一步依舊是點(diǎn)擊download ? 3 點(diǎn)擊鏈接Files for Microsoft Windows 步驟閱讀 ? 4 The Apache HTTP Server Project itself does not provide binary releases of software, only source code.Individual committers may provide binary packages as a convenience, but it is not a release deliverable.If you cannot compile the Apache HTTP Server yourself, you can obtain a binary package from numerous binary distributions available on the Internet.Popular options for deploying Apache httpd, and, optionally, PHP and MySQL, on Microsoft Windows, include: ApacheHaus Apache Lounge BitNami WAMP Stack WampServer XAMPP 大致意思是說(shuō)apache本身不提供已編譯的安裝包,只提供源碼,如果你自己無(wú)法編譯,可以選擇下面這些官方推薦的第三方提供編譯的網(wǎng)站。
其中后兩個(gè)是有名的wamp以及xampp集成環(huán)境,如果只想下載apache可以選擇前三個(gè)網(wǎng)站,這里我們第一個(gè)ApacheHaus為例。? 5 打開(kāi)ApacheHaus之后你會(huì)發(fā)現(xiàn)這個(gè)網(wǎng)站上有各種windows版本,可以盡情選擇你要下載的版本。? 6 點(diǎn)擊紅框中的圖標(biāo)即可開(kāi)始下載,x86是32位的,x64是64位的,根據(jù)自己的操作系統(tǒng)選擇下載
? Apache安裝
? 2 打開(kāi)ApacheHaus之后你會(huì)發(fā)現(xiàn)這里有許多的windows版的Apache版本 這里簡(jiǎn)單的介紹一下:x86代表32位,x64代表64位。根據(jù)自己安裝的系統(tǒng)選擇
關(guān)于vc9與vc11,這里的選擇要跟PHP對(duì)應(yīng)才能穩(wěn)定的運(yùn)行。(按照PHP官方提供的資源來(lái)看,PHP 5.5以后的版本官方只提供了VC11版本的產(chǎn)品程序,PHP5.3/5.4版還有VC9版本的產(chǎn)品程序)? 3 注意建立好自己的文件存放方式,方便以后管理
下 載完畢后解壓,將解壓的 Apache24文件夾復(fù)制到自己的項(xiàng)目目錄里面。你的項(xiàng)目根目錄為E:/wamp/Apache24/htdocs即DocumentRoot的定義。如果想放到其他目錄下,需要修改httpd.conf,包括ServerRoot、DocumentRoot、Directories,ScriptAlias。需要改為你的Apache目錄的地址。? 4 因?yàn)檫@里我們下載的是官方源碼包,所以需要把Apache服務(wù)安裝到我們的計(jì)算機(jī)上面
開(kāi)啟控制臺(tái):win+R 輸入cmd 命令行下進(jìn)入到apache下面的bin目錄,輸入
httpd-k install 把a(bǔ)pache安裝成windows后臺(tái)服務(wù)。? 5 所有基本的命令都可以在Apache官網(wǎng)上找到,下面是一些常用的命令 ? 6 最后使用ApacheMonitor來(lái)管理apache服務(wù)器 訪(fǎng)問(wèn)測(cè)試是否成功
? 對(duì)大家遇到的一些問(wèn)題做下簡(jiǎn)單總結(jié)
1、由于apache默認(rèn)是監(jiān)聽(tīng)80端口,如果你的電腦iis是啟動(dòng)狀態(tài),并且也使用了80端口,apache將無(wú)法正常啟動(dòng),需要先停止iis,另外迅雷也可能會(huì)使用80端口,所以也要關(guān)閉迅雷。查看80端口是否被占用,命令行下輸入: netstat-aon|findstr “80” 如果看到如圖的結(jié)果,說(shuō)明80端口已被使用,需要先關(guān)閉相關(guān)軟件,或者修改apache默認(rèn)的監(jiān)聽(tīng)端口
打開(kāi)apache目錄下的conf/httpd.conf 搜索 “Listen 80” 修改為L(zhǎng)isten 8088 保存之后再重新啟動(dòng)apache
2、httpd-k install 輸入該命令后查看服務(wù)是否安裝成功 開(kāi)始-->運(yùn)行-->services.msc-->確定
打開(kāi)后如果在服務(wù)列表能夠看到apache字樣,說(shuō)明,服務(wù)安裝成功,可以直接點(diǎn)擊左邊的啟動(dòng)按鈕來(lái)啟動(dòng)服務(wù) ? 13
3、服務(wù)無(wú)法正常安裝,首先確定軟件32位和64位是否和自己的系統(tǒng)匹配 其 次,看電腦有沒(méi)有安裝軟件相應(yīng)的運(yùn)行包,比如你下載的是VC9版本,那么你需要先安裝Microsoft Visual C++ 2008 Redistributable,同理VC11版本你需要安裝Microsoft Visual C++ 2012 Update 4 Redistributable Package(X86 & x64)在ApacheHaus網(wǎng)站的最底部提供了相應(yīng)的Visual Studio Redistributable Packages下載鏈接
第二篇:Web測(cè)試工具小結(jié)
Web測(cè)試工具小結(jié)
單元測(cè)試方面:(對(duì)開(kāi)發(fā)人員比較有用)J-Unit工具。
功能測(cè)試方面:E-test是個(gè)不錯(cuò)的選擇,功能很強(qiáng)大,由于不是采用Post URL的方式回放腳本,所以可以支持多內(nèi)碼的測(cè)試數(shù)據(jù)(當(dāng)然要程序支持)?;旧峡梢詰?yīng)付大部分的Web Site。
如果只是利用腳本回放代替手工勞動(dòng),或者做對(duì)頁(yè)面響應(yīng)數(shù)的性能測(cè)試,Microsoft Web Application Stress Tool是個(gè)不錯(cuò)的選擇。
另外,在性能測(cè)試方面,PureLoad也是一個(gè)不錯(cuò)的工具,完全用Java寫(xiě)成,可以測(cè)試各種C/S程序,如SMTP Server等。這兩個(gè)工具都是使用Post URL的方法測(cè)試Web Application的。對(duì)大量使用JavaScript的頁(yè)面不太適合。當(dāng)然,如果程序在Unix,linux下面運(yùn)行的話(huà),可以直接編寫(xiě)Shell腳本程序,更加方便。
另外,還有很多專(zhuān)門(mén)的工具,比如說(shuō)Linkbot是專(zhuān)門(mén)作頁(yè)面鏈接測(cè)試的。
另外,測(cè)試流程管理工具也有不少,個(gè)人用過(guò)也一直在用的是Test Plan Control,短小精悍,不錯(cuò)。
至于WinRunner和LoadRunner之類(lèi),因?yàn)闆](méi)有License,所以都沒(méi)怎么用過(guò),慚愧。不過(guò)我看過(guò)一篇英國(guó)人評(píng)價(jià)英國(guó)測(cè)試市場(chǎng)上最流行的五個(gè)軟件的文章。WinRunner得分最高。
測(cè)試工具從測(cè)試的方法上可以分為兩種:白盒測(cè)試和黑盒測(cè)試
白盒測(cè)試工具主要有:
內(nèi)存資源泄漏檢查:Numega中的bouncechecker,Rational的Purify等
代碼覆蓋率檢查:Numega中的truecoverage,Rational的Purecoverage,Telelogic公司的logiscope, Macabe公司的Macabe等
代碼性能檢查:Numega中的truetime,Rational的Quantify等
代碼靜態(tài)度量分析質(zhì)量檢查工具:logiscope和Macabe等
黑盒測(cè)試工具主要有:
客戶(hù)端功能測(cè)試:MI公司的winrunner,compuware的qarun,Rational的SQA robot等等
服務(wù)器端壓力性能測(cè)試: MI公司的winload,compuware的qaload,Rational的SQA load等等
Web測(cè)試工具:MI公司的Astra系列,rsw公司的e-test suite等等
測(cè)試管理工具:rational的test manager,compuware的qadirector等等,此外還有缺陷跟蹤工具 trackrecord等。
數(shù)據(jù)庫(kù)測(cè)試工具:TestBytes
黑盒測(cè)試工具:QACenter、SQATeamTest,Rational Viaual Test。
回歸測(cè)試工具:Rational TeamTest,WinRunner(MI公司)
WEB系統(tǒng)測(cè)試工具:TEST,Workberch,Web Appication Stress Tool(WAS)
白盒測(cè)試工具:Numega、PuRe、軟件糾錯(cuò)工具(Rational Purity)。
嵌入式測(cè)試工具:Logiscope(靜態(tài)測(cè)試工具)、CodeTest。
系統(tǒng)負(fù)荷測(cè)試工具:RationalPerformance
涵蓋測(cè)試工具范圍評(píng)估工具
軟件性能測(cè)試工具:LoadRunner(MI產(chǎn)品)、Rational Visual Qantify
測(cè)試管理工具:TestDirector(MI產(chǎn)品支持整個(gè)生命周期中測(cè)試流程管理)
第三篇:WEB測(cè)試總結(jié)
WEB測(cè)試總結(jié)(架構(gòu),設(shè)計(jì))精華部分
1、總計(jì)架構(gòu)測(cè)試
1)瘦客戶(hù)端,業(yè)務(wù)邏輯規(guī)則多數(shù)在服務(wù)器端執(zhí)行。如新聞?wù)军c(diǎn)、門(mén)戶(hù)網(wǎng)站、信息發(fā)布網(wǎng)站等。
2)胖客戶(hù)端,安全性要求較高、交互操作頻繁、業(yè)務(wù)邏輯復(fù)雜。銀行系統(tǒng)、網(wǎng)絡(luò)游戲、網(wǎng)上辦公系統(tǒng)等。
2、Web架構(gòu)組成部分是否滿(mǎn)足需求
成本、功能、安全性要求、容量要求、傳輸實(shí)時(shí)性。
3、服務(wù)器配置分布是否滿(mǎn)足要求
Web服務(wù)器、應(yīng)用服務(wù)器、數(shù)據(jù)庫(kù)服務(wù)器可以分布在不同物理機(jī)器上也可以分布相同的物理機(jī)器上,一般優(yōu)先考慮獨(dú)立數(shù)據(jù)庫(kù)服務(wù)器,Web服務(wù)器、應(yīng)用服務(wù)器可以在相同的機(jī)器上。
4、客戶(hù)端設(shè)計(jì)測(cè)試
1)功能設(shè)置測(cè)試:信息服務(wù)、辦公自動(dòng)化、Internet支持; 2)信息組織結(jié)構(gòu)測(cè)試:線(xiàn)性結(jié)構(gòu)、分層結(jié)構(gòu)、非線(xiàn)性結(jié)構(gòu); 3)頁(yè)面設(shè)計(jì)測(cè)試:a.頁(yè)面一致性測(cè)試
b.用戶(hù)界面友好性及導(dǎo)航直觀性測(cè)試;、c.是否適合多種瀏覽器; d.頁(yè)文件的命名; e.頁(yè)面布局技術(shù)。
5、服務(wù)器端設(shè)計(jì)測(cè)試
1)容量規(guī)劃測(cè)試:點(diǎn)擊率、延遲和流量、服務(wù)器資源;
2)系統(tǒng)安全測(cè)試:a.常識(shí)性安全策略,取消不必要的協(xié)議、控制寫(xiě)權(quán)限、取消服務(wù)器目錄瀏覽屬性、記錄日志等; b.使用加密技術(shù);
c.構(gòu)造防火墻,網(wǎng)絡(luò)級(jí)、應(yīng)用級(jí)、電路級(jí); d.構(gòu)建網(wǎng)絡(luò)防毒體系。3)數(shù)據(jù)庫(kù)設(shè)計(jì)測(cè)試。
6、Web開(kāi)發(fā)測(cè)試
1)源代碼分析,主要是使用檢查工具來(lái)完成; 2)鏈接測(cè)試,主要借助工具來(lái)完成; 3)框架測(cè)試:a.自動(dòng)調(diào)整窗口大??; b.是否提供滾動(dòng)條;
c.打開(kāi)新頁(yè)面是否正常。4)表格測(cè)試,隨窗體變化自動(dòng)調(diào)整大??; 5)圖形測(cè)試:a.顏色飽和度及對(duì)比度; b.鏈接標(biāo)識(shí);
c.圖形顯示是否正確。
1、與一般應(yīng)用軟件相比,Web測(cè)試有以下區(qū)別:
第一、Web測(cè)試的側(cè)重點(diǎn)是性能、安全、易用性、兼容
第二、測(cè)試工具有所不同,如鏈接測(cè)試、表單測(cè)試、界面測(cè)試
2、功能測(cè)試
一、客戶(hù)端的選擇,優(yōu)先測(cè)試流行的客戶(hù)客戶(hù)端;
二、客戶(hù)端瀏覽器的配置
三、客戶(hù)端的顯示設(shè)置
四、內(nèi)容測(cè)試
3、鏈接測(cè)試
一、該鏈接將用戶(hù)帶到它所說(shuō)明的地方
二、被鏈接的頁(yè)面是存在的
三、保證沒(méi)有孤立頁(yè)面
工具有WEBCHECK、LINKBOT、TESTPARTNER、XENU等
4、鏈接測(cè)試工具的優(yōu)勢(shì):
一、簡(jiǎn)單易用
二、在實(shí)現(xiàn)上采用多線(xiàn)程技術(shù),檢查速度特別快;
三、對(duì)斷開(kāi)的鏈接可以再次測(cè)試,可以避免誤判;
四、沒(méi)有檢查鏈接的數(shù)量限制,只受系統(tǒng)資源的約束;
五、可以分析Web應(yīng)用的結(jié)構(gòu);
六、檢查結(jié)果可以分類(lèi)查看,自動(dòng)生成HTML格式的報(bào)告;
5、Web應(yīng)用鏈接主要測(cè)試點(diǎn)如下
一、測(cè)試內(nèi)部鏈接和外部鏈接中成功和失敗的鏈接點(diǎn),以及應(yīng)用中不被其他鏈接調(diào)用的頁(yè)面;
二、測(cè)試鏈接中新網(wǎng)頁(yè)、老網(wǎng)頁(yè)、慢網(wǎng)頁(yè)以及丟失的圖象標(biāo)題標(biāo)簽和屬性標(biāo)簽等;
三、分析Web應(yīng)用的結(jié)構(gòu)是否合理,包括顯示和某個(gè)URL相關(guān)的鏈接以及按照標(biāo)題、描述、作者、大小、最后修改時(shí)間、類(lèi)型為URL鏈接分類(lèi)等。
6、易用性測(cè)試
易用性測(cè)試要考慮以下幾個(gè)方面: 1)用戶(hù)的計(jì)算機(jī)使用經(jīng)驗(yàn);
2)用戶(hù)對(duì)瀏覽器以及Web的使用經(jīng)驗(yàn); 3)用戶(hù)的業(yè)務(wù)專(zhuān)業(yè)知識(shí)。
7、Web系統(tǒng)的易用性測(cè)試分為三個(gè)方面: 1)界面測(cè)試
2)輔助功能測(cè)試 3)圖形測(cè)試
一、界面測(cè)試要考慮以下幾個(gè)問(wèn)題 A.WEB應(yīng)用系統(tǒng)的最終用戶(hù)群是誰(shuí)? B.WEB應(yīng)用界面的設(shè)計(jì)策略是什么? C.頁(yè)面中各元素布局的協(xié)調(diào)性 a.各元素位置的協(xié)調(diào)性 b.各元素顏色的協(xié)調(diào)性
c.各元素大小比例的協(xié)調(diào)性 D.不同頁(yè)面風(fēng)格的統(tǒng)一性
E.用戶(hù)在界面中操作的便利性 F.界面動(dòng)態(tài)操作測(cè)試
a.屏幕分辯率設(shè)置的影響
b.瀏覽窗口最大化/最小化的影響 c.選定目標(biāo)元素的置中與縮放
二、輔助功能測(cè)試 A.使用說(shuō)明,這個(gè)沒(méi)有多大意義,WEB網(wǎng)頁(yè)按F1彈出來(lái)的頁(yè)面都是IE的幫助頁(yè)面,除非有特定的幫助說(shuō)明內(nèi)容; B.導(dǎo)航功能 C.站點(diǎn)地圖
D.幫助,這個(gè)沒(méi)有多大意義,WEB網(wǎng)頁(yè)按F1彈出來(lái)的頁(yè)面都是IE的幫助頁(yè)面,除非有特定的幫助說(shuō)明內(nèi)容;
第四篇:服務(wù)器性能測(cè)試典型工具介紹
服務(wù)器整機(jī)系統(tǒng)性能測(cè)試工具
一臺(tái)服務(wù)器系統(tǒng)的性能可以按照處理器、內(nèi)存、存儲(chǔ)、網(wǎng)絡(luò)幾部分來(lái)劃分,而針對(duì)不同的應(yīng)用,可能會(huì)對(duì)某些部分的性能要求高一些。
Iometer(004km.cn):存儲(chǔ)子系統(tǒng)讀寫(xiě)性能測(cè)試
Iometer是Windows系統(tǒng)下對(duì)存儲(chǔ)子系統(tǒng)的讀寫(xiě)性能進(jìn)行測(cè)試的軟件??梢燥@示磁盤(pán)系統(tǒng)的最大IO能力、磁盤(pán)系統(tǒng)的最大吞吐量、CPU使用率、錯(cuò)誤信息等。用戶(hù)可以通過(guò)設(shè)置不同的測(cè)試的參數(shù),有存取類(lèi)型(如sequential ,random)、讀寫(xiě)塊大小(如64K、256K),隊(duì)列深度等,來(lái)模擬實(shí)際應(yīng)用的讀寫(xiě)環(huán)境進(jìn)行測(cè)試。
Iometer操作簡(jiǎn)單,可以錄制測(cè)試腳本,可以準(zhǔn)確有效的反映存儲(chǔ)系統(tǒng)的讀寫(xiě)性能,為各大服務(wù)器和存儲(chǔ)廠商所廣泛采用。
Sisoft Sandra(004km.cn):linux下I/O性能測(cè)試
現(xiàn)在有很多的服務(wù)器系統(tǒng)都是采用linux操作系統(tǒng),在linux平臺(tái)下測(cè)試I/O性能可以采用iozone。
iozone是一個(gè)文件系統(tǒng)的benchmark工具,可以測(cè)試不同的操作系統(tǒng)中文件系統(tǒng)的讀寫(xiě)性能??梢詼y(cè)試Read, write, re-read, re-write, read backwards, read strided, fread, fwrite, random read, pread ,mmap, aio_read, aio_write 等等不同的模式下的硬盤(pán)的性能。測(cè)試所有這些方面,生成excel文件,另外, iozone還附帶了用gnuplot畫(huà)圖的腳本。該軟件用在大規(guī)模機(jī)群系統(tǒng)上測(cè)試NFS的性能,更加具有說(shuō)服力。
Netperf(004km.cn):網(wǎng)絡(luò)性能測(cè)試
Netperf可以測(cè)試服務(wù)器網(wǎng)絡(luò)性能,主要針對(duì)基于TCP或UDP的傳輸。Netperf根據(jù)應(yīng)用的不同,可以進(jìn)行不同模式的網(wǎng)絡(luò)性能測(cè)試,即批量數(shù)據(jù)傳輸(bulk data transfer)模式和請(qǐng)求/應(yīng)答(request/reponse)模式。Netperf測(cè)試結(jié)果所反映的是一個(gè)系統(tǒng)能夠以多快的速度向另外一個(gè)系統(tǒng)發(fā)送數(shù)據(jù),以及另外一個(gè)系統(tǒng)能夠以多塊的速度接收數(shù)據(jù)。
Netperf工具以client/server方式工作。server端是netserver,用來(lái)偵聽(tīng)來(lái)自client端的連接,client端是 netperf,用來(lái)向server發(fā)起網(wǎng)絡(luò)測(cè)試。在client與server之間,首先建立一個(gè)控制連接,傳遞有關(guān)測(cè)試配置的信息,以及測(cè)試的結(jié)果;在控制連接建立并傳遞了測(cè)試配置信息以后,client與server之間會(huì)再建立一個(gè)測(cè)試連接,用來(lái)來(lái)回傳遞著特殊的流量模式,以測(cè)試網(wǎng)絡(luò)的性能。
針對(duì)應(yīng)用的測(cè)試工具
系統(tǒng)的負(fù)載和壓力需要采用負(fù)載測(cè)試工具進(jìn)行,虛擬一定數(shù)量的用戶(hù)來(lái)測(cè)試系統(tǒng)的表現(xiàn),看是否滿(mǎn)足預(yù)期的設(shè)計(jì)指標(biāo)要求。負(fù)載測(cè)試的目標(biāo)是測(cè)試當(dāng)負(fù)載逐漸增加時(shí),系統(tǒng)組成部分的相應(yīng)輸出項(xiàng),例如通過(guò)量、響應(yīng)時(shí)間、CPU負(fù)載、內(nèi)存使用等如何決定系統(tǒng)的性能,例如穩(wěn)定性和響應(yīng)等。
負(fù)載測(cè)試一般使用工具完成,有LoadRunner,Webload,QALoad等,主要的內(nèi)容都是編寫(xiě)出測(cè)試腳本,腳本中一般包括用戶(hù)常用的功能,然后運(yùn)行,得出報(bào)告。
使用壓力測(cè)試工具對(duì)web服務(wù)器進(jìn)行壓力測(cè)試。測(cè)試可以幫助找到一些大型的問(wèn)題,如死機(jī)、崩損、內(nèi)存泄漏等,因?yàn)橛行┐嬖趦?nèi)存泄漏問(wèn)題的程序,在運(yùn)行一兩次時(shí)可能不會(huì)出現(xiàn)問(wèn)題,但是如果運(yùn)行了成千上萬(wàn)次,內(nèi)存泄漏得越來(lái)越多,就會(huì)導(dǎo)致系統(tǒng)崩滑。
Loadrunner:預(yù)測(cè)系統(tǒng)行為和性能的負(fù)載測(cè)試工具
目前,業(yè)界中有不少能夠做性能和壓力測(cè)試的工具,Mercury(美科利)Interactive公司的LoadRunner是其中的佼佼者,也已經(jīng)成為了行業(yè)的規(guī)范,目前最新的版本8.1。
LoadRunner 是一種預(yù)測(cè)系統(tǒng)行為和性能的負(fù)載測(cè)試工具,通過(guò)模擬上千萬(wàn)用戶(hù)實(shí)施并發(fā)負(fù)載及實(shí)時(shí)性能監(jiān)測(cè)的方式來(lái)確認(rèn)和查找問(wèn)題,LoadRunner 能夠?qū)φ麄€(gè)企業(yè)架構(gòu)進(jìn)行測(cè)試,LoadRunner 適用于各種體系架構(gòu),能支持廣范的協(xié)議和技術(shù)(如Web、Ftp、Database等),能預(yù)測(cè)系統(tǒng)行為并優(yōu)化系統(tǒng)性能。它通過(guò)模擬實(shí)際用戶(hù)的操作行為和實(shí)行實(shí)時(shí)性能監(jiān)測(cè),來(lái)幫助您更快的查找和發(fā)現(xiàn)問(wèn)題。Loadrunner是一個(gè)強(qiáng)大有力的壓力測(cè)試工具,它的腳本可以錄制生成,自動(dòng)關(guān)聯(lián)。測(cè)試場(chǎng)景面向指標(biāo),實(shí)現(xiàn)了多方監(jiān)控。而且測(cè)試結(jié)果采用圖表顯示,可以自由拆分組合。一般來(lái)說(shuō)可以按照服務(wù)器硬件、網(wǎng)絡(luò)、應(yīng)用程序、操作系統(tǒng)、中間件的順序進(jìn)行分析。
Webload:WEB性能壓力測(cè)試
webload是RadView公司推出的一個(gè)性能測(cè)試和分析工具,它讓web應(yīng)用程序開(kāi)發(fā)者自動(dòng)執(zhí)行壓力測(cè)試;webload通過(guò)模擬真實(shí)用戶(hù)的操作,生成壓力負(fù)載來(lái)測(cè)試web的性能。
用戶(hù)創(chuàng)建的是基于javascript的測(cè)試腳本,稱(chēng)為議程agenda,用它來(lái)模擬客戶(hù)的行為,通過(guò)執(zhí)行該腳本來(lái)衡量web應(yīng)用程序在真實(shí)環(huán)境下的性能。當(dāng)前最高版本是6.0。webload提供巡航控制器cruise control的功能,利用巡航控制器,可以預(yù)定義web應(yīng)用程序應(yīng)該滿(mǎn)足的性能指標(biāo),然后測(cè)試系統(tǒng)是否滿(mǎn)足這些需求指標(biāo);cruise control能夠自動(dòng)把負(fù)載加到web應(yīng)用程序,并將在此負(fù)荷下能夠訪(fǎng)問(wèn)程序的客戶(hù)數(shù)量生成報(bào)告。
webload能夠在測(cè)試會(huì)話(huà)執(zhí)行期間對(duì)監(jiān)測(cè)的系統(tǒng)性能生成實(shí)時(shí)的報(bào)告,這些測(cè)試結(jié)果通過(guò)一個(gè)易讀的圖形界面顯示出來(lái),并可以導(dǎo)出到excel和其他文件里。
第五篇:性能測(cè)試學(xué)習(xí)總結(jié)
性能測(cè)試學(xué)習(xí)總結(jié)
一、明確性能測(cè)試的范圍
例如:以iptv系統(tǒng)為例,是需要測(cè)試bss頁(yè)面、中間件具體接口、boss/crm具體接口
二、明確性能測(cè)試的指標(biāo) 例如:
1、支持最大并發(fā)用戶(hù)數(shù)是多少?(壓力測(cè)試)
2、每秒n個(gè)用戶(hù)并發(fā),能正常持續(xù)運(yùn)行多久?(負(fù)載測(cè)試)
3、在系統(tǒng)用戶(hù)為n個(gè)的情況下,每秒x個(gè)用戶(hù)并發(fā),持續(xù)運(yùn)行y分鐘,查看系統(tǒng)硬件io、cpu、內(nèi)存;查看軟件平均吞度量、tps、平均響應(yīng)時(shí)間、事務(wù)成功率、事務(wù)失敗率、錯(cuò)誤率等(性能測(cè)試)、響應(yīng)時(shí)間:事務(wù)從開(kāi)始到完成所花費(fèi)時(shí)間
平均吞吐量:指單位時(shí)間內(nèi)系統(tǒng)處理用戶(hù)的請(qǐng)求數(shù)
TPS:transaction per second 服務(wù)器單位時(shí)間處理的事務(wù)數(shù)(事務(wù)數(shù)/運(yùn)行時(shí)間s)
事務(wù):指訪(fǎng)問(wèn)并可能更新數(shù)據(jù)庫(kù)中各種數(shù)據(jù)項(xiàng)的一個(gè)程序執(zhí)行單元。例如訂購(gòu)操作,它含有多個(gè)請(qǐng)求
事務(wù)成功率:成功事務(wù)數(shù)占完成總事務(wù)數(shù)的比率 事務(wù)失敗率:失敗事務(wù)數(shù)占完成總事務(wù)數(shù)的比率
三、定義數(shù)據(jù)模型
1、目標(biāo)系統(tǒng)用戶(hù)數(shù)、目標(biāo)每秒并發(fā)數(shù)、硬件系統(tǒng)配置情況,如下:模板
IPTV-BSS 性能指標(biāo).docx
四、設(shè)計(jì)性能測(cè)試方案
IPTV BSS四川電信版本性能
五、搭建性能測(cè)試環(huán)境
1、盡可能模擬現(xiàn)網(wǎng)的環(huán)境與組網(wǎng)結(jié)構(gòu)
2、前臺(tái)應(yīng)用和后臺(tái)數(shù)據(jù)庫(kù)安裝在獨(dú)立干凈的服務(wù)器上。
3、當(dāng)前性能測(cè)試環(huán)境分別為:192.168.12.11(前臺(tái))192.168.12.31(數(shù)據(jù)庫(kù))192.167.12.177(Loadrunner)
六、構(gòu)造性能測(cè)試數(shù)據(jù)
1、使用LR、QTP自動(dòng)化工具構(gòu)造(比較慢,不需要了解表結(jié)構(gòu),但是需要了解業(yè)務(wù)流)
2、編寫(xiě)存儲(chǔ)過(guò)程構(gòu)造用戶(hù)、包月、訂購(gòu)數(shù)據(jù)(比較快,需要對(duì)相關(guān)表結(jié)構(gòu)和數(shù)據(jù)庫(kù)了解)
七、錄制、調(diào)試測(cè)試腳本
1、中間件接口目前是web services協(xié)議,因當(dāng)前測(cè)試指標(biāo)均超過(guò)100個(gè)并發(fā),故使用web(http/html)協(xié)議錄制。中間件接口錄制頁(yè)面:
2、boss接口當(dāng)前有兩種協(xié)議,一種是web services協(xié)議,一種是sockets協(xié)議,因當(dāng)前測(cè)試指標(biāo)最大為100個(gè)并發(fā),故可以使用web services協(xié)議或http/html協(xié)議錄制。
3、bss頁(yè)面基于ie運(yùn)行,故使用web(http/html)協(xié)議錄制。
注明:當(dāng)前中間件接口,四川boss接口,浙江電信bss部分頁(yè)面均有現(xiàn)成的腳本,如果其它局點(diǎn)需要測(cè)試可使用原有的腳本調(diào)試即可。
詳細(xì)參考:LoadRunner性能測(cè)試_劉雙林_20110115.doc
2.3/2.4章節(jié) 進(jìn)行學(xué)習(xí)
八、執(zhí)行性能測(cè)試場(chǎng)景
1、按照測(cè)試方案文檔中的測(cè)試用例執(zhí)行即可。
2、在執(zhí)行性能測(cè)試過(guò)程中會(huì)具體使用到性能測(cè)試工具LR。關(guān)于性能測(cè)試工具的使用方法網(wǎng)上有大把資料。請(qǐng)自行學(xué)習(xí):場(chǎng)景設(shè)置、參數(shù)化等
詳細(xì)參考:LoadRunner性能測(cè)試.doc
3章節(jié) 進(jìn)行學(xué)習(xí)
九、監(jiān)控并記錄性能測(cè)試結(jié)果
1、硬件性能:bss應(yīng)用服務(wù)器cpu、內(nèi)存;數(shù)據(jù)庫(kù)服務(wù)器cpu、內(nèi)存、io 內(nèi)存、cpu 不高于70% ;IO不高于80% 否則可能存在性能瓶頸 統(tǒng)計(jì)方式:
(1)通過(guò)命令在服務(wù)器上查詢(xún)
內(nèi)存 sar-r 5 120
(每5s刷新1次共刷新120次)cpu sar-u 5 120 io
iostat 5 120(2)在服務(wù)器上安裝rpc.rstatd工具,通過(guò)LR客戶(hù)端窗口監(jiān)控記錄
2、軟件性能:平均吞度量、tps、平均響應(yīng)時(shí)間、事務(wù)成功率、事務(wù)失敗率、錯(cuò)誤率等(場(chǎng)景運(yùn)行完畢可通過(guò)loadrunner工具導(dǎo)出性能測(cè)試結(jié)果),是否達(dá)標(biāo)是要與性能測(cè)試指標(biāo)進(jìn)行比對(duì)。
詳細(xì)參考:LoadRunner性能測(cè)試.doc
4章節(jié) 進(jìn)行學(xué)習(xí)
十、分析性能測(cè)試結(jié)果輸出總結(jié)報(bào)告
1、將實(shí)際測(cè)試結(jié)果和性能測(cè)試指標(biāo)進(jìn)行對(duì)比,總結(jié)出不達(dá)標(biāo)測(cè)試對(duì)象及具體測(cè)試數(shù)據(jù)
2、測(cè)試與開(kāi)發(fā)人員根據(jù)性能測(cè)試數(shù)據(jù),從硬件環(huán)境和軟件本身進(jìn)行分析。例如:優(yōu)化硬件配置、軟件處理邏輯、數(shù)據(jù)庫(kù)架構(gòu)腳本等。
3、具體分析的方法:一般是具體問(wèn)題具體分析,查找瓶頸時(shí)按以下順序,由易到難。(1)服務(wù)器硬件瓶頸
(2)網(wǎng)絡(luò)瓶頸(對(duì)局域網(wǎng),可以不考慮)(3)服務(wù)器操作系統(tǒng)瓶頸(參數(shù)配置)(4)中間件瓶頸(參數(shù)配置,數(shù)據(jù)庫(kù),web 服務(wù)器等)(5)應(yīng)用瓶頸(SQL 語(yǔ)句、數(shù)據(jù)庫(kù)設(shè)計(jì)、業(yè)務(wù)邏輯、算法等)注:以上過(guò)程并不是每個(gè)分析中都需要的,要根據(jù)測(cè)試目的和要求來(lái)確定分析的深度。對(duì)一些要求低的,我們分析到應(yīng)用系統(tǒng)在將來(lái)大的負(fù)載壓力(并發(fā)用戶(hù)數(shù)、數(shù)據(jù)量)下,系統(tǒng)的硬件瓶頸在哪兒就夠了。
十一、LoadRunner性能測(cè)試工具操作文檔
LoadRunner性能測(cè)試.doc
loadrunner8.1教材.pdf