ab 测试模块高并发

转载:http://gekie.iteye.com/blog/1704235程序员

 

做为程序员,写好一个模块后,不知道这个模块在高并发的状况下能不能平稳过渡,这里所说的平稳过渡是指,在高并发的状况下还能正常访问并处理相关数据库服务请求并返回数据。APACHE自带的测试工具AB(apache benchmark),能帮我来测试个人模块可否胜任高并发(不要也要看数据库服务器和应用服务器的性能)。数据库

AB在APACHE的bin目录下,以命令行的方式执行:apache

格式: ./ab [options] [http://]hostname[:port]/path服务器

参数说明:网络

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

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

t timelimit //测试所进行的最大秒数高并发

 

其余的参数看中就用。工具

参数不少,通常咱们用 -c 和 -n 参数就能够了. 例如:
./ab -c 1000 -n 1000 http://127.0.0.1/index.jsp
性能

这个表示同时处理1000个请求并运行1000次index.jsp文件.

其返回的结果集是有不少内容,咱们选择关键的几个看看就大概知道咱们的模块性能了

我比较关心的几个结果:

Concurrency Level: 1000
Time taken for tests: 1.190 seconds //处理1000个并发请求总共花了1.19秒
Complete requests: 1000 //完成处理的请求量
Failed requests: 0 //请求失败数
Write errors: 0
Non-2xx responses: 1000
Total transferred: 164000 bytes //总共传输了多少流量
HTML transferred: 0 bytes
Requests per second: 840.58 [#/sec] (mean) //平均一个请求花840.58毫秒 你们最关心的指标之一,至关于 LR 中的每秒事务数,后面括号中的 mean 表示这是一个平均值
Time per request: 1189.651 [ms] (mean) //你们最关心的指标之二,至关于 LR 中的平均事务响应时间,后面括号中的 mean 表示这是一个平均值
Time per request: 1.190 [ms] (mean, across all concurrent requests) //每一个请求实际运行时间的平均值 ms是毫秒
Transfer rate: 134.62 [Kbytes/sec] received //传输速率 能够帮助排除是否存在网络流量过大致使响应时间延长的问题

相关文章
相关标签/搜索