壓力測試工具ab使用入門

mac自己自帶了ab,可是有併發限制,若是有須要能夠從新安裝abhtml

其餘系統安裝說明前端

Ubuntu:sudo apt-get install apache2-utilsCentOS:yum -y install httpd-toolsWindows系統Apache下載地址:https://www.apachehaus.com/cgi-bin/download.plx
複製代碼

一、ab是什麼?node

ab是apache自帶的壓力測試工具,英文名apache bench。ab很是實用,它不只能夠對apache服務器進行網站訪問壓力測試,也能夠對或其它類型的服務器進行壓力測試。好比nginx、tomcat、IIS等。nginx

二、大前端趨勢下,前端時常也會有一些node的接口研發需求,本文簡單記錄一下用壓力測試一個簡單node服務express

// index.js
const express = require('express');let app =express();//設置跨域訪問app.all('*', function (req, res, next) {    res.header("Access-Control-Allow-Origin", "*");    res.header("Access-Control-Allow-Headers", "X-Requested-With");    res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");    res.header("X-Powered-By",' 3.2.1')    res.header("Content-Type", "application/json;charset=utf-8");    next()}); app.get('/', (req, res) => {    res.send('jone');});//配置服務端口var server = app.listen(8000, () => {    console.log( `localhost:8000`);});
複製代碼

(1) 執行node服務apache

node index.js
複製代碼

(2) 執行json

ab -n 100 -c 10 http://localhost:8000/

ab -n 100 -c 10 http://localhost:8000/ >> jone.html
複製代碼

輸出成爲html文件展現跨域

參數說明tomcat

ab工具經常使用參數:-n :總共的請求執行數,缺省是1;-c: 併發數,缺省是1;-t:測試所進行的總時間,秒爲單位,缺省50000s-p:POST時的數據文件-w: 以HTML表的格式輸出結果
複製代碼

result服務器

// apache版本說明
This is ApacheBench, Version 2.3 <$Revision: 1843412 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking localhost (be patient).....done
// 請求返回的header類型
Server Software:
// 請求url
Server Hostname:        localhost
// 端口號
Server Port:            8000

Document Path:          /
// 第一個成功返回的文檔的字節
Document Length:        4 bytes

// 併發數量
Concurrency Level:      10
// 從創建鏈接到最後完成接受的總時間
Time taken for tests:   0.038 seconds
// 總共完成的請求數
Complete requests:      100
// 失敗的請求數
Failed requests:        0
// 從服務器接收的總字節數
Total transferred:      46300 bytes
// HTML接收字節數,減去了Total transferred中HTTP響應數據中的頭信息的長度
HTML transferred:       400 bytes
// rps(吞吐率)
Requests per second:    2613.01 [#/sec] (mean)
// tpr(用戶平均請求等待時間)
Time per request:       3.827 [ms] (mean)
// 服務器處理單個請求的平均時間 mean 表示平均
Time per request:       0.383 [ms] (mean, across all concurrent requests)
// 這些請求在單位時間內從服務器獲取的數據長度 
// 計算公式:Total trnasferred/ Time taken for testsTransfer rate:          1181.47 [Kbytes/sec] received
// 鏈接消耗時間分解
Connection Times (ms)
              min  mean[+/-sd] median   max
              最小值 平均值 標準差  中間值    最大值Connect:        0    0   0.1      0       0
Processing:     1    4   1.0      3       6
Waiting:        0    2   0.8      2       5
Total:          1    4   1.1      3       6
//按完成請求的百分比,得出完成請求中花費時間最長的那一個請求的時間,也就是這些請求完成時間的最大值(毫秒)
Percentage of the requests served within a certain time (ms)
  50%      3
  66%      4
  75%      4
  80%      5
  90%      6
  95%      6
  98%      6
  99%      6
 100%      6 (longest request)
//100%請求完成時間的最大值是208毫秒(最長請求)
複製代碼

一、吞吐率(Requests per second)

服務器併發處理能力的量化描述,單位是reqs/s,指的是在某個併發用戶數下單位時間內處理的請求數。某個併發用戶數下單位時間內能處理的最大請求數,稱之爲最大吞吐率。
記住:吞吐率是基於併發用戶數的。這句話表明了兩個含義:
a、吞吐率和併發用戶數相關;
b、不一樣的併發用戶數下,吞吐率通常是不一樣的。
計算公式:總請求數/處理完成這些請求數所花費的時間,即:
Request per second=Complete requests/Time taken for tests
必需要說明的是,這個數值表示當前機器的總體性能,值越大越好。

二、併發鏈接數(The number of concurrent connections)

併發鏈接數指的是某個時刻服務器所接受的請求數目,簡單的講,就是一個會話。

三、併發用戶數(Concurrency Level)

要注意區分這個概念和併發鏈接數之間的區別,一個用戶可能同時會產生多個會話,也即鏈接數。在HTTP/1.1下,IE7支持兩個併發鏈接,IE8支持6個併發鏈接,FireFox3支持4個併發鏈接,因此相應的,咱們的併發用戶數就得除以這個基數。

四、用戶平均請求等待時間(Time per request)

計算公式:處理完成全部請求數所花費的時間/(總請求數/併發用戶數),即:Time per request=Time taken for tests/(Complete requests/Concurrency Level)

五、服務器平均請求等待時間(Time per request:across all concurrent requests)

計算公式:處理完成全部請求數所花費的時間/總請求數,即: Time taken for/testsComplete requests 能夠看到,它是吞吐率的倒數。同時,它也等於用戶平均請求等待時間/併發用戶數,即: Time per request/Concurrency Level

相關文章
相關標籤/搜索