Apache ab压力测试工具Window下载和用法详解「建议收藏」

Apache ab压力测试工具Window下载和用法详解「建议收藏」Apache ab压力测试工具Window下载和用法详解

大家好,又见面了,我是你们的朋友全栈君。

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105909.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • microsoft visio 2010激活成功教程版_visio2010激活成功教程版百度云

    microsoft visio 2010激活成功教程版_visio2010激活成功教程版百度云特别说明:软件仅供技术交流,请勿用于商业及非法用途,如产生法律纠纷与本人无关Microsoftvisio2013professional激活成功教程软件下载地址:链接:https://pan.baidu.com/s/1ycZHBzzF2KtGOwAs1LbHMQ密码:npkl激活成功教程步骤:文件—&gt;账号—&gt;更改产品密钥—&gt;输入如下序列号即可。序列号:…

    2022年10月5日
    1
  • Android ListView默认选中某一项[通俗易懂]

    Android ListView默认选中某一项[通俗易懂]很多时候,在listview加载数据之后,我们希望默认选中第一项,然后我们在setAdapter之后写上如下代码:listview.getChildAt(0).setBackgroundResource(R.color.white);发现程序崩溃:NullPointerException,事实上,setAdapter()是异步的 ,调用了这个方法之后ListView的item并没

    2022年7月17日
    12
  • Java记事本编写HelloWorld程序[通俗易懂]

    Java记事本编写HelloWorld程序[通俗易懂]目录1编写第一个Java程序1.1高端的技术,往往使用最朴素的方法1.2编译后运行2main方法3输出语句4分号作用1编写第一个Java程序让我们编写一个简单的Java程序,它将在屏幕上打印“HelloWorld”。publicclassMain{publicstaticvoidmain(String[]args){System.out.println(“HelloWorld”);}}在上面的例子中,我们命

    2022年5月10日
    37
  • [黑苹果系列] M910x完美黑苹果系统安装教程 – 4 安装&设置macOS系统 – System Install

    [黑苹果系列] M910x完美黑苹果系统安装教程 – 4 安装&设置macOS系统 – System Install在BIOS中设置U盘启动,然后经过一段跑码,可以进到MacOS的界面,之后进入安装界面,先选择磁盘工具然后选择磁盘工具->显示所有设备,即可看见左侧的物理磁盘名称选择所需要安装的盘,选择抹掉然后,填好磁盘名和格式为APFS,方案为GUID分区图,然后抹掉完成后退出磁盘工具,选择安装macOSBigSur点击继续和同意后,选择相应的磁盘,点击继续,等待安装然后会安装完后会开始跑码重启后继续安装,到设置界面大约要重启…

    2022年6月9日
    62
  • 按位取反怎么运算_按位取反在线计算器

    按位取反怎么运算_按位取反在线计算器一、首先二进制在计算机的内存中是以补码的形式存储二、正数的补码=原码=反码,负数的反码=原码的取反(二进制数的符号位除外,一般来说在二进制的左边的最高位)补码=反码+1三、按位取反怎么算按位取反:二进制的每一位都取反(符号位+数据位)公式法:~x=-(x+1)举两个例子:~11=-(11+1)=-12~(-11)=10公式法的内部是如何计算的呢:以~11为例:~11的计算步骤:计算11的补码转二进制:01011计算补码:01011按位取反:10100(按位取反

    2022年8月14日
    21
  • SpringCloud Eurake客户端操作相关笔记

    SpringCloud Eurake客户端操作相关笔记2019独角兽企业重金招聘Python工程师标准>>>…

    2022年6月2日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号