大家好,又见面了,我是你们的朋友全栈君。
ab是apache自带的网站压力测试工具。
使用起来非常的简单和方便。
不仅仅是可以apache服务器进行网站访问压力测试,还可以对其他类型的服务器进行压力测试。
比如nginx,tomcat,IIS等
首先当然是下载安装了。
在这里只讲window下在下载安装
官方下载地址:,(https://www.apachehaus.com/cgi-bin/download.plx)
下载完成后解压
我就直接解压到d盘的apacheab中去了
修改解压根目录下的conf/httpd.conf文件的端口配置,默认是80端口,应该是被占用了,无法安装,可以自行修改为其他,我在这里修改为8088端口
然后输入命令安装:
httpd -k install
第一次安装错误是因为端口没有改,被占用了,应该是被iis占用的。
开始测试
ab -n 100 -c 10 http://www.baidu.com/s
-n 表示请求数,-c 表示并发数.
s为path,表示指定测试地址,不指定可能会报”ab: invalid url” 错误.
另外还有-t 表示多少s内并发和请求
测试出来的数据如下:
D:\apacheab\Apache24\bin>ab -n 100 -c 10 http://www.baidu.com/s
This is ApacheBench, Version 2.3 <$Revision: 1807734 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking www.baidu.com (be patient).....done
Server Software: BWS/1.1
##服务器软件和版本
Server Hostname: www.baidu.com
##请求的地址/域名
Server Port: 80
##端口
Document Path: /s
##请求的路径
Document Length: 112435 bytes
##页面数据/返回的数据量
Concurrency Level: 10
##并发数
Time taken for tests: 4.764 seconds
##共使用了多少时间
Complete requests: 100
##请求数
Failed requests: 99
##失败请求 百度为什么失败这么多,应该是百度做了防范
(Connect: 0, Receive: 0, Length: 99, Exceptions: 0)
Total transferred: 11342771 bytes
##总共传输字节数,包含http的头信息等
HTML transferred: 11247622 bytes
##html字节数,实际的页面传递字节数
Requests per second: 20.99 [#/sec] (mean)
##每秒多少请求,这个是非常重要的参数数值,服务器的吞吐量
Time per request: 476.427 [ms] (mean)
##用户平均请求等待时间
Time per request: 47.643 [ms] (mean, across all concurrent requests)
##服务器平均处理时间,也就是服务器吞吐量的倒数
Transfer rate: 2325.00 [Kbytes/sec] received
##每秒获取的数据长度
Connection Times (ms)
min mean[+/-sd] median max
Connect: 22 41 12.4 39 82
##连接的最小时间,平均值,中值,最大值
Processing: 113 386 211.1 330 1246
##处理时间
Waiting: 25 80 43.9 73 266
##等待时间
Total: 152 427 210.1 373 1283
##合计时间
Percentage of the requests served within a certain time (ms)
50% 373
## 50%的请求在373ms内返回
66% 400
## 60%的请求在400ms内返回
75% 426
80% 465
90% 761
95% 930
98% 1192
99% 1283
100% 1283 (longest request)
---------------------
因为ab工具消耗小,所以有些人也用来进行ddos攻击,算一种ddos攻击工具
问题1:apr_socket_recv: Connection timed out (110)
问题分析:从ab.c源码可以看到,如果没有设置-r参数,ab在socket接收到错误后,apr_err会使用exit即刻退出。
解决方案:ab使用时加上-r参数,如:ab -r -n200000 -c10000 http://xxxx
附ab.c的部分源码(apache/support/ab.c,apache版本不同,这里的源代码行数可能不同)
1398 if (recverrok) {
1399 bad++;
1400 close_connection©;
1401 if (verbosity >= 1) {
1402 char buf[120];
1403 fprintf(stderr,”%s: %s (%d)\n”, “apr_socket_recv”, apr_strerror(status, buf, sizeof bu f), status);
1404 }
1405 return;
1406 } else {
1407 apr_err(“apr_socket_recv”, status);
1408 }
问题2:apr_socket_recv: Connection reset by peer (104)
解决方案同问题1,在遇到错误时,加-r参数,避免即刻退出
问题3:apr_pollset_poll: The timeout specified has expired (70007)
问题分析:从ab.c源码可以看到,在socket等待server的响应超过超时时间(-s可指定,未指定默认30s),则调用apr_err退出。
解决方案:找到如下(1758,1759)两行代码,注释掉,重新编译apache/support目录(可单独support,无需重新编译apache)
1755 do {
1756 status = apr_pollset_poll(readbits, aprtimeout, &n, &pollresults);
1757 } while (APR_STATUS_IS_EINTR(status));
1758 if (status != APR_SUCCESS)
1759 apr_err(“apr_pollset_poll”, status);
问题四:
使用apache ab做压力测试时出现apr_poll:The timeout specified has expired错误
使用apache 的ab做压力测试时,当压力过大,例如请求1000000次,在没有执行完就报apr_poll:The timeout specified has expired错误,解决办法,使用-k(发送keep-alive指令到服务器端),同时修改web服务器下的/etc/sysctl.conf,在里 面添加如下内容:
net.ipv4.netfilter.ip_conntrack_max = 3276800
net.ipv4.tcp_tw_recycle = 0
net.ipv4.tcp_tw_reuse = 0
net.ipv4.tcp_orphan_retries = 1
net.ipv4.tcp_fin_timeout = 25
net.ipv4.tcp_max_orphans = 8192
net.ipv4.ip_local_port_range = 32768 61000
如果已经存在,试着加大net.ipv4.netfilter.ip_conntrack_max的值,然后使用
sysctl -p /etc/sysctl.conf
原文链接:https://blog.csdn.net/qq_26525215/article/details/79182674
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/105909.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...