使用ab 进行并发压力测试 - 参与商 - 博客园 https://www.cnblogs.com/shenshangzz/p/8340640.html

使用ab 进行并发压力测试

 

ab全称为:apache bench。

是apache自带的压力测试工具。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试。比如nginx、tomcat、IIS等。

安装ab命令:

ubuntu:

sudo apt-get install apache2-utils

centos:

yum install apr-util

# 安装依赖 yum-utils中的yumdownload 工具
# 如果没有找到 yumdownload 命令可以
yum install yum-utils

使用:

简单使用说明
1. 最基本的关心两个选项 -c -n
例: ab -n 1000 -c 100 http://www.baidu.com/

-n 1000 即: 共发送1000个请求
-c 100 即:每次并发100个

测试结果:

命令:ab -n 1000 -c 1000 http://www.test.net/switch/get

This is ApacheBench, Version 2.3 <$Revision: 1528965 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/ Benchmarking www.test.net(be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Completed 1000 requests
Finished 1000 requests Server Software: nginx/1.10.2
Server Hostname: www.test.net
Server Port: 80 Document Path: /switch/get
Document Length: 85 bytes Concurrency Level: 1000
Time taken for tests: 2.296 seconds
Complete requests: 1000
Failed requests: 170
(Connect: 0, Receive: 0, Length: 170, Exceptions: 0)
Non-2xx responses: 170
Total transferred: 496990 bytes
HTML transferred: 103360 bytes
Requests per second: 435.62 [#/sec] (mean)
Time per request: 2295.555 [ms] (mean)
Time per request: 2.296 [ms] (mean, across all concurrent requests)
Transfer rate: 211.43 [Kbytes/sec] received Connection Times (ms)
min mean[+/-sd] median max
Connect: 15 132 47.7 145 201
Processing: 89 428 225.7 382 2121
Waiting: 85 358 223.0 293 2121
Total: 198 559 233.0 512 2286 Percentage of the requests served within a certain time (ms)
50% 512
66% 603
75% 697
80% 751
90% 850
95% 910
98% 935
99% 1243
100% 2286 (longest request)

结果分析:

服务器信息:

  采用nginx服务器,域名是www.test.net,端口号80端口。

Server Software:        nginx/1.10.2
Server Hostname: www.test.net
Server Port: 80

文档信息:

  文档路径/switch/get,文档长度85字节(http响应的正文长度)

Document Path:          /switch/get
Document Length: 85 bytes

重要指标:

  Concurrency Level: 1000  // 1000个并发请求

  Time taken for tests: 2.296 seconds  // 整个测试持续时间

  Complete requests: 1000  // 完成了1000个请求

  Failed requests: 170 (Connect: 0, Receive: 0, Length: 170, Exceptions: 0)  // 失败的请求数170

  Non-2xx responses: 170  // 170个不是2开头的响应码,比如缓存的304

  Total transferred: 496990 bytes  // 整个场景中的网络传输量

  HTML transferred: 103360 bytes  // 整个场景中的HTML内容传输量

  Requests per second: 435.62 [#/sec] (mean)

  // 吞吐率(大家最关心的指标之一)

  服务器并发处理能力的量化描述,单位是reqs/s,指的是在某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。

  记住:吞吐率是基于并发用户数的。这句话代表了两个含义:

  a、吞吐率和并发用户数相关

  b、不同的并发用户数下,吞吐率一般是不同的

  计算公式:总请求数/处理完成这些请求数所花费的时间,即

  Request per second=Complete requests/Time taken for tests

  必须要说明的是,这个数值表示当前机器的整体性能,值越大越好。

  Time per request: 2295.555 [ms] (mean)

  // 用户平均请求等待时间,大家最关心的指标之二

  计算公式:处理完成所有请求数所花费的时间/(总请求数/并发用户数)

  Time per request: 2.296 [ms] (mean, across all concurrent requests)

  // 服务器平均请求处理时间,大家最关心的指标之三

  计算公式:处理完成所有请求数所花费的时间/总请求数

  Transfer rate: 211.43 [Kbytes/sec] received  // 平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题

Concurrency Level:      1000
Time taken for tests: 2.296 seconds
Complete requests: 1000
Failed requests: 170
(Connect: 0, Receive: 0, Length: 170, Exceptions: 0)
Non-2xx responses: 170
Total transferred: 496990 bytes
HTML transferred: 103360 bytes
Requests per second: 435.62 [#/sec] (mean)
Time per request: 2295.555 [ms] (mean)
Time per request: 2.296 [ms] (mean, across all concurrent requests)
Transfer rate: 211.43 [Kbytes/sec] received

网络上消耗的时间的分解:

Connection Times (ms)
min mean[+/-sd] median max
Connect: 15 132 47.7 145 201
Processing: 89 428 225.7 382 2121
Waiting: 85 358 223.0 293 2121
Total: 198 559 233.0 512 2286

每个请求处理时间的分布情况,50%的处理时间在512ms内,66%的处理时间在603ms内...,重要的是看90%的处理时间:

Percentage of the requests served within a certain time (ms)
50% 512
66% 603
75% 697
80% 751
90% 850
95% 910
98% 935
99% 1243
100% 2286 (longest request)

Download - The Apache Portable Runtime Project http://apr.apache.org/download.cgi

使用ab 进行并发压力测试的更多相关文章

  1. 面向Web应用的并发压力测试工具——Locust实用攻略

    1. 概述 该方案写作目的在于描述一个基于Locust实现的压力测试,文中详细地描述了如何利用locustfile.py文件定义期望达成的测试用例,并利用Locust对目标站点进行并发压力测试. 特别 ...

  2. apache的ab命令做压力测试

    1. 最基本的关心两个选项 -c -n 例: ./ab -c 100 -n 10000 http://127.0.0.1/index.php -c 100 即:每次并发100个-n 10000 即: ...

  3. windows Apache ab安装及压力测试

    一:安装 ab是Apache自带的网站压力测试工具.使用起来非常的简单和方便.不仅仅是可以Apache服务器进行网站访问压力测试,还可以对其他类型的服务器进行压力测试.比如nginx,tomcat,I ...

  4. ab工具进行压力测试

    简介与安装 ab:Apache Benchmark,只要我们安装了Apache,就能够在Apache的安装目录中找到它. yum | apt 安装的Apache  ab的目录一般为/usr/bin 也 ...

  5. (转)使用Apache的ab工具进行压力测试

    转:http://www.cnblogs.com/luckyliu/archive/2012/03/04/2379306.html Apache附带的ab工具(本机使用的PHP环境是WAMP集成环境, ...

  6. ab命令执行压力测试

    ab是Apache超文本传输协议(HTTP)的性能测试工具:设计意图是描绘当前所安装的Apache的执行性能,主要是显示你安装的Apache每秒可以处理多少个请求:ab不仅仅能进行基于apache服务 ...

  7. AB(ApacheBench)工具 -- 压力测试

    服务器负载太大而影响程序效率也是很常见的,Apache服务器自带有一个叫AB(ApacheBench)的工具,可以对服务器进行负载测试 同时美多商城的秒杀功能也会被高负载影响,从而导致超卖现象 安装x ...

  8. 用jmeter进行多用户并发压力测试 [转]

    近日manager要求对项目进行压力测试,开始对jmeter进行了研究.jmeter是Apache一个开源项目,可对各种项目进行测试,甚至包括junit. 测试要求如下,多用户同时登陆web应用程序, ...

  9. 用jmeter进行多用户并发压力测试

    测试要求如下,多用户同时登陆web应用程序,并进行操作,查看在多用户操作下,程序的performence.恰好,jemter下有个CSV Data Set Config,它用来设定一组参数,以便在向程 ...

随机推荐

  1. centos7设置系统语言为中文

    centos7设置系统语言为中文 修改 /etc/locale.conf  文件内容为: LANG="zh_CN.GB18030" LANGUAGE="zh_CN.GB1 ...

  2. CentOS 挂载NTFS分区的两种方法

    第一种是安装内核模块,可到 http://sourceforge.net/projects/linux-ntfs/files/ 下载,需下载与你系统内核想对应的版本,使用uname -a 查看当前内核 ...

  3. EasyMvc入门教程-基本控件说明(2)定时器

    我们有时候希望系统能自动刷新后台数据或者做某个动作,那么定时器的作用就体现出来了. EasyMvc默认提供的服务器可以定时调前端方法与定时调后端方法,先看例子: 定时调客户端事件 实现代码: @Htm ...

  4. 【GLSL教程】(三)在OpenGL中向shader传递信息 【转】

    http://blog.csdn.net/racehorse/article/details/6634830 引言 一个OpenGL程序可以用多种方式和shader通信.注意这种通信是单向的,因为sh ...

  5. 2017.2.28 activiti实战--第六章--任务表单(二)外置表单

    学习资料:<Activiti实战> 第六章 任务表单(二)外置表单 6.3 外置表单 考虑到动态表单的缺点(见上节),外置表单使用的更多. 外置表单的特点: 页面的原样显示 字段值的自动填 ...

  6. VC++动态链接库(DLL)编程深入浅出(一)

    1.概论 先来阐述一下DLL(Dynamic Linkable Library)的概念,你可以简单的把DLL看成一种仓库,它提供给你一些可以直接拿来用的变量.函数或类.在仓库的发展史上经历了“无库-静 ...

  7. C 标准库 - <assert.h>

    C 标准库 - <assert.h> 简介 C 标准库的 assert.h头文件提供了一个名为 assert 的宏,它可用于验证程序做出的假设,并在假设为假时输出诊断消息. 已定义的宏 a ...

  8. 【SQL】SQL Server中存储过程的调试方法

    1.以管理员用户登录DB服务器,把域用户追加到「Administrators」组. 2.在本机上以域用户登录,启动VS. 3.追加DB连接 4.右击要debug的存储过程,选择「ストアドプロシージャに ...

  9. GUID概念

     GUID概念 GUID: 即Globally Unique Identifier(全球唯一标识符) 也称作 UUID(Universally Unique IDentifier) . GUID是 ...

  10. 分享个免费的货币汇率API

    先上API文档链接:https://www.juhe.cn/docs/api/id/23,支持人民币牌价.外汇汇率查询:数据仅供参考,交易时以银行柜台成交价为准. 人民币牌价 接口地址:http:// ...