简单好用的服务器压力测试小工具 ab

前段时间,创建了一个小接口,用来测试阿里云的一个表格存储的IO能力,就用到了一个压测小工具,叫ab(apachebeach),是apache的一个性能测试工具,其设计意图是描绘当前所安装的Apache的执行性能,主要是显示你安装的Apache每秒可以处理多少个请求。

如果你本身用的就是apache的服务器,那么这个小工具已经在你的Apache安装目录/bin/下了,你可以直接cd到那路径去使用。

如果你像我一样,用的是Nginx服务器的话,就需要单独装一下apache的工具包httpd-tools:

yum -y install httpd-tools

ab的使用非常简单,就一条命令:

ab [可选的参数选项] 需要进行压力测试的url

ab --help可以查看所有的参数,在这里给大家列一下中文的解释(该解释摘自互联网):

-n    在测试会话中所执行的请求个数。默认时,仅执行一个请求。

-c    一次产生的请求个数。默认是一次一个。

-t    测试所进行的最大秒数。其内部隐含值是-n 50000,它可以使对服务器的测试限制在一个固定的总时间以内。默认时,没有时间限制。

-p    包含了需要POST的数据的文件。

-P    对一个中转代理提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。无论服务器是否需要(即, 是否发送了401认证需求代码),此字符串都会被发送。

-T    POST数据所使用的Content-type头信息。

-v    设置显示信息的详细程度-4或更大值会显示头信息,3或更大值可以显示响应代码(404,200等),2或更大值可以显示警告和其他信息。

-V    显示版本号并退出。

-w    以HTML表的格式输出结果。默认时,它是白色背景的两列宽度的一张表。

-i    执行HEAD请求,而不是GET。

-x    设置<table>属性的字符串。

-X    对请求使用代理服务器。

-y    设置<tr>属性的字符串。

-z    设置<td>属性的字符串。

-C    对请求附加一个Cookie:行。其典型形式是name=value的一个参数对,此参数可以重复。

-H    对请求附加额外的头信息。此参数的典型形式是一个有效的头信息行,其中包含了以冒号分隔的字段和值的对(如,"Accept-Encoding:zip/zop;8bit")。

-A    对服务器提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。无论服务器是否需要(即,是否发送了401认证需求代码),此字符串都会被发送。

-h    显示使用方法。

-d    不显示"percentage served within XX [ms] table"的消息(为以前的版本提供支持)。

-e    产生一个以逗号分隔的(CSV)文件,其中包含了处理每个相应百分比的请求所需要(从1%到100%)的相应百分比的(以微妙为单位)时间。由于这种格式已经“二进制化”,所以比'gnuplot'格式更有用。

-g    把所有测试结果写入一个'gnuplot'或者TSV(以Tab分隔的)文件。此文件可以方便地导入到Gnuplot,IDL,Mathematica,Igor甚至Excel中。其中的第一行为标题。

-i    执行HEAD请求,而不是GET。

-k    启用HTTP KeepAlive功能,即在一个HTTP会话中执行多个请求。默认时,不启用KeepAlive功能。

-q    如果处理的请求数大于150,ab每处理大约10%或者100个请求时,会在stderr输出一个进度计数。此-q标记可以抑制这些信息。

列了那么多,其实最常用的就是-n(请求数)和-c(并发数)

最常用的命令例子如下(每次发送10条,一共发送100条的请求到www.wead.mobi进行压测):

ab -n 100 -c 10 http://www.wead.mobi/

结果如下:

150446_MeXM_1777369.png

下面我们分解开来一个个解释:

150645_xMd4_1777369.png

首先是服务器的一些常规信息,用的是Nginx服务器,主机名为www.wead.mobi,端口号是80。

150835_6dXG_1777369.png

这段是关于请求的文档的相关信息,所在位置“/”,文档的大小为26263 bytes(此为http响应的正文长度)

150907_pU77_1777369.png

这些就是一些压测得到的比较有用的指标了(最有用的三个指标已加粗):

Concurrency Level: 并发请求数
Time taken for tests: 整个测试持续的时间
Complete requests: 完成的请求数
Failed requests:失败的请求数
Write errors:写入错误数
Total transferred: 整个场景中的网络传输量
HTML transferred: 整个场景中的HTML内容传输量
Requests per second:吞吐率,后面括号中的 mean 表示这是一个平均值
Time per request:用户平均请求等待时间,后面括号中的 mean 表示这是一个平均值
Time per request: 服务器平均请求处理时间

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

151659_kGNE_1777369.png

连接时各阶段的消耗的时间的一个分解

152247_iZJe_1777369.png

这个是各个比例的请求消耗的时间(单位是毫秒),如50%的请求消耗11ms以内的,90%的请求是消耗14ms以内的,所有请求的消耗时间都是16ms以内的。

以上就是ab压测小工具的一个简单介绍,有兴趣的可以自行谷歌百度深入研究一下。

转载于:https://my.oschina.net/lonelycode/blog/1527574

脚本使用简介: /******************************************************************************** void tcc_tell_user(long len,const char *fmt,...) void tcc_init_stochastic() int tcc_produce_stochastic(int a,int b) tcc_sscanf tcc_sprintf tcc_strcpy tcc_strcmp tcc_strstr tcc_strcat tcc_memcpy tcc_memcmp tcc_memset tcc_strlen tcc_malloc tcc_free *********************************************************************************/ void get_hex_string(unsigned char *in_dat,int in_len,char *ou_hex) { int i; char *t=(char*)tcc_malloc(8); ou_hex[0]=0; for(i=0;i<in_len;i++) { if(i%0x04==0 && i!=0) tcc_strcat(ou_hex," "); if(i%0x10==0 && i!=0) tcc_strcat(ou_hex,"\n"); tcc_sprintf(t,"X ",in_dat[i]); tcc_strcat(ou_hex,t); } tcc_free(t); } void msg_init() { // tcc_init_stochastic(); } void *msg_short_connect_form_data(long t,long s,long c,long *len) { char *data=(char*)tcc_malloc(128); *len=128; *(long*)(data+0x00)=128; *(long*)(data+0x04)=1; *(long*)(data+0x08)=0; *(long*)(data+0x0C)=0; int n=tcc_produce_stochastic(100,50000); tcc_sprintf(data+0x10,"hello%d",n); tcc_strcpy(data+0x20,"123456"); return data; } int msg_short_connect_recv_data(long s,long c,void *dat,long len) { unsigned char *ou_dat=(unsigned char*)tcc_malloc(5120); get_hex_string(dat,len,ou_dat); tcc_tell_user(5120,"s:%d c:%d len:%d\n%s\n\n",s,c,len,ou_dat); tcc_free(ou_dat); return 1; } void *msg_long_connect_form_data(long op,long s,long c,long *len) { char *data=(char*)tcc_malloc(128); *len=128; *(long*)(data+0x00)=128; *(long*)(data+0x04)=1; *(long*)(data+0x08)=0; *(long*)(data+0x0C)=0; int n=tcc_produce_stochastic(100,50000); tcc_sprintf(data+0x10,"hello%d",n); tcc_strcpy(data+0x20,"123456"); return data; } int msg_long_connect_recv_data(long s,long c,void *dat,long len) { unsigned char *ou_dat=(unsigned char*)tcc_malloc(5120); get_hex_string(dat,len,ou_dat); tcc_tell_user(5120,"s:%d c:%d len:%d\n%s\n\n",s,c,len,ou_dat); tcc_free(ou_dat); return 1; } void msg_free_data(void *arg) { tcc_free(arg); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值