1:吞吐率(Requests per second)
服務(wù)器并發(fā)處理能力的量化描述,單位是reqs/s,指的是某個(gè)并發(fā)用戶數(shù)下單位時(shí)間內(nèi)處理的請(qǐng)求數(shù)。某個(gè)并發(fā)用戶數(shù)下單位時(shí)間內(nèi)能處理的最大請(qǐng)求數(shù),稱之為最大吞吐率。
記住:吞吐率是基于并發(fā)用戶數(shù)的。這句話代表了兩個(gè)含義,1:吞吐率和并發(fā)用戶數(shù)相關(guān);2:不同的并發(fā)用戶數(shù)下,吞吐率一般是不同的。
計(jì)算公式:總請(qǐng)求數(shù) / 處理完成這些請(qǐng)求數(shù)所花費(fèi)的時(shí)間,即
Request per second = Complete requests / Time taken for tests
2:并發(fā)連接數(shù)(The number of concurrent connections)
并發(fā)連接數(shù)指的是某個(gè)時(shí)刻服務(wù)器所接受的請(qǐng)求數(shù)目,簡(jiǎn)單的講,就是一個(gè)會(huì)話。
3:并發(fā)用戶數(shù)(The number of concurrent users,Concurrency Level)
要注意區(qū)分這個(gè)概念和并發(fā)連接數(shù)之間的區(qū)別,一個(gè)用戶可能同時(shí)會(huì)產(chǎn)生多個(gè)會(huì)話,也即連接數(shù)。在HTTP/1.1下,IE7支持兩個(gè)并發(fā)連接,IE8支持6個(gè)并發(fā)連接,F(xiàn)ireFox3支持4個(gè)并發(fā)連接,所以相應(yīng)的,我們的并發(fā)用戶數(shù)就得除以這個(gè)基數(shù)。
4:用戶平均請(qǐng)求等待時(shí)間(Time per request)
計(jì)算公式:處理完成所有請(qǐng)求數(shù)所花費(fèi)的時(shí)間/ (總請(qǐng)求數(shù) / 并發(fā)用戶數(shù)),即
Time per request = Time taken for tests /( Complete requests / Concurrency Level)
5:服務(wù)器平均請(qǐng)求等待時(shí)間(Time per request: across all concurrent requests)
計(jì)算公式:處理完成所有請(qǐng)求數(shù)所花費(fèi)的時(shí)間 / 總請(qǐng)求數(shù),即
Time taken for / testsComplete requests
可以看到,它是吞吐率的倒數(shù)。
同時(shí),它也=用戶平均請(qǐng)求等待時(shí)間/并發(fā)用戶數(shù),即
Time per request / Concurrency Level
二:具體做法
1:壓力測(cè)試工具選擇
重量級(jí)的工具有Visual Studio 自帶的工具,還有Loader Runner(LR),輕量級(jí)的工具有Apache項(xiàng)目中的ApacheBench,簡(jiǎn)稱ab。你可以在這里下載:ab.zip。
2:ab的簡(jiǎn)單使用及參數(shù)介紹
以上測(cè)試,基于我的一個(gè)asp.net的頁(yè)面。對(duì)于壓力測(cè)試,必須時(shí)時(shí)刻刻做,如果不知道自己的應(yīng)用能夠承載多少的并發(fā)用戶數(shù),那基本上就是在扔定時(shí)炸彈。
您可能感興趣的文章:- Mysqlslap MySQL壓力測(cè)試工具 簡(jiǎn)單教程
- 并發(fā)數(shù)據(jù)庫(kù)壓力測(cè)試的shell腳本代碼
- android壓力測(cè)試命令monkey詳解
- Web性能壓力測(cè)試工具Siege使用教程
- Linux下Web性能壓力測(cè)試工具h(yuǎn)ttp_load使用教程
- Linux下Web網(wǎng)站壓力測(cè)試工具Webbench使用教程