• 为什么写博客,是因为遇到的坑,不希望别人在踩一遍!
  • 选择了,剩下的就是坚持和努力-------致自己!
  • 当能力达不到梦想时,更需要学习,努力,拼搏

压力测试之一Apache Bench

Linux运维 雪豹 7年前 (2017-08-22) 1039次浏览 0个评论

网站性能压力测试是性能调优过程中必不可少的一环。只有让服务器处在高压情况下才能真正体现出各种设置所暴露的问题。Apache中有个自带的,名为ab的程序,可以对Apache或其它类型的服务器进行网站访问压力测试。

1.1 ApacheBench命令原理:

ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问。它的测试目标是基于URL的,因此,既可以用来测试Apache的负载压力,也可以测试nginx、lighthttp、tomcat、IIS等其它Web服务器的压力。

ab命令对发出负载的计算机要求很低,既不会占用很高CPU,也不会占用很多内存,但却会给目标服务器造成巨大的负载,其原理类似CC攻击。自己测试使用也须注意,否则一次上太多的负载,可能造成目标服务器因资源耗完,严重时甚至导致死机。

注意:如果不想安装apache但是又想使用ab命令的话,我们可以直接安装apache的工具包httpd-tools。如下:

[root@lb03 ~]# yum -y install httpd-tools
查看ab是否安装成功,可以切换到上述目录下,使用ab –V命令进行检测。如下:
[root@lb03 ~]# ab -V
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

ab网站压力测试命令
格式: ab [options] [http://]hostname[:port]/path
-n 测试会话中所执行的请求个数,默认时,仅执行一个请求
-c 一次产生的请求个数。默认是一次一个
-t 测试所进行的最大秒数
-v 设置显示信息的详细程度 – 4或更大值会显示头信息, 3或更大值可以显示响应代码(404, 200等), 2或更大值可以显示警告和其他信息。 -V 显示版本号并退出。
4个比较长用的参数 若有其他需要man下吧
一般工作中我们只用-n 和 -c:

例子1:

提示:如果我们直接用ab命令默认是一次并发

[root@lb03 ~]# ab http://www.zxblinux.com/
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.zxblinux.com (be patient).....done

Server Software: nginx #表示被测试的Web服务器软件名称
Server Hostname: www.zxblinux.com #表示请求的URL主机名
Server Port: 80 #表示被测试的Web服务器软件的监听端口

Document Path: / #表示请求的URL中的根绝对路径,通过该文件的后缀名,我们一般可以了解该请求的类型。
Document Length: 36041 bytes #表示HTTP响应数据的正文长度。

Concurrency Level: 1 #表示并发用户数,这是我们设置的参数之一。
Time taken for tests: 0.209 seconds #表示所有这些请求被处理完成所花费的总时间。
Complete requests: 1 #表示总请求数量,这是我们设置的参数之一。
Failed requests: 0 #表示失败的请求数量,这里的失败是指请求在连接服务器、发送数据等环节发生异常,以及无响应后超时的情况。
#如果接收到的HTTP响应数据的头信息中含有2XX以外的状态码,则会在测试结果中显示另一个名为
#“Non-2xx responses”的统计项,用于统计这部分请求数,这些请求并不算在失败的请求中。
Write errors: 0
Total transferred: 36982 bytes #表示所有请求的响应数据长度总和
HTML transferred: 36041 bytes #表示所有请求的响应数据中正文数据的总和,也就是减去了Total transferred中HTTP响应数据中的头信息的长度。
Requests per second: 4.79 [#/sec] (mean) #吞吐率,计算公式:Complete requests/Time taken for tests
Time per request: 208.905 [ms] (mean) #用户平均请求等待时间
Time per request: 208.905 [ms] (mean, across all concurrent requests) #服务器平均请求等待时间
Transfer rate: 172.88 [Kbytes/sec] received #表示这些请求在单位时间内从服务器获取的数据长度
#网络上消耗的时间的分解
Connection Times (ms)
min mean[+/-sd] median max
Connect: 12 12 0.0 12 12
Processing: 197 197 0.0 197 197
Waiting: 184 184 0.0 184 184
Total: 209 209 0.0 209 209

案例2:

模拟2个用户 请求总数 5次并发 一共 10次请求http://www.zxblinux.com/

[root@lb03 ~]# ab -n 5 -c 2 http://www.zxblinux.com/
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking www.zxblinux.com (be patient).....done
Server Software: NWS_SPMid
Server Hostname: www.zxblinux.com
Server Port: 80
Document Path: /
Document Length: 36041 bytes
Concurrency Level: 2
Time taken for tests: 0.118 seconds
Complete requests: 5
Failed requests: 0
Write errors: 0
Total transferred: 182480 bytes
HTML transferred: 180205 bytes
Requests per second: 42.24 [#/sec] (mean)
Time per request: 47.352 [ms] (mean)
Time per request: 23.676 [ms] (mean, across all concurrent requests)
Transfer rate: 1505.34 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 10 12 1.6 12 14
Processing: 24 27 2.7 28 31
Waiting: 18 20 2.6 19 25
Total: 36 39 3.3 40 43
Percentage of the requests served within a certain time (ms)
50% 40
66% 41
75% 41
80% 43
90% 43
95% 43
98% 43
99% 43
100% 43 (longest request)

通过上图,测试结果也一目了然,nginx测试出的吞吐率为:Requests per second: 42.24 [#/sec] (mean)。
1、根据前面我们提到的性能指标Requests per second吞吐率越高,服务器性能越好。
2、如果Failed requests: 0表示当前没有失败的请求数量。如果失败的请求数量 过多,或者出现也需要注意。


有需要可以联系微信xuebao19930721和加入微信群
喜欢 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址