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