Apache ab压力测试时出现大量的错误原因分析
最近有一个测试任务,是测试nginx的并发请求到底能够达到多少的,
于是就用ab工具对其进行压力测试。
这压力测试一执行,问题就来了:发起10000次请求,并发100,错误的情况能达到30%--50%了!
不应该有这么多啊?哪儿出问题了?于是就用loadrunner 和jemeter做了同样的测试,失败率为0,响应时间也差不多。这不科学啊?
没有办法,只好去百度google一下,大多数结果说的是apache ab工具的使用方法,参数介绍,结果分析什么的。一直没有想要的结果,最后找到了:http://stackoverflow.com/questions/579450/load-testing-with-ab-fake-failed-requests-length
上面是全英语的,讲到了这个问题。
The apache benchmarking tool (ab) assumes that length of response content will be the same during entire test.
if the connection is closed server-side before the total amount of bytes declared in the Content-Length header has not been received by the client. That can happen if there are other parties between the client and the server, for example, naive handcrafted load balancers (my case).
大概是说如果返回的内容长度不一样,或是连接断了就会出现错误。先分析一下连接吧,我们的网络是非常好的,而且测试端和被测试的对象机器在同一网段,网络是没有任何问题的。
现在就分析一下内容的长度了,因为我是对同一个查询发起的请求,按原理来说结果不会不一样啊?于是就将请求的结果打到日志中好好分析一下,最好才发现原来返回结果中有一个:“took”字段,这个字段标识的是每次请求所花费的时间。并发请求的时候,所花费的时候肯定是不会一样的,如果时间不一样,就导致返回结果长度不同,于是ab就给记录成failure了,这是ab的一个Bug,我们没有办法解决。找到了问题所在,就好办了,最后换成其他的压力测试工具来测试。
总结:
一, 遇到问题的时候,不能固定思维,如果一直认定是自己的程序问题,在那反复优化,这是没有结果的。要大胆的去怀疑各个方面的问题,像这次测试工具的问题。
二, 解决问题的办法很多,要多尝试一下,多试几个工具,这样对比着来,才能达到解决问题的结果。
三, 善于总结,问题解决后要善于总结,把问题产生的原因,解决办法记录下来,这样才能不断的进步!
Apache ab压力测试时出现大量的错误原因分析的更多相关文章
- apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104))
apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104)) 今天用apache 自带的ab工具测试,当并发量达到1000多的时 ...
- apache ab压力测试报错apr_socket_recv
apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104)) apache 自带的ab工具测试,当并发量达到1000多的时候报错如下 ...
- 使用apache的ab压力测试时失败请求原因
只要出现 Failed requests 就会多出现一行要求失败的各原因的数据统计,分别有 Connect, Length,与 Exception 三种,分别代表的意义为:Connect 无 ...
- apache ab压力测试
今天提到压力测试,想起以前看到的ab,于是又重新查找了下资料,并记录了下. ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问. 它的测试目标是基于URL的,因此,既可以用来 ...
- apache ab 压力测试工具
Apache的ab命令模拟多线程并发请求,测试服务器负载压力,也可以测试nginx.lighthttp.IIS等其它Web服务器的压力.Apache附带的ab工具(使用的PHP环境是WAMP集成环境, ...
- apache ab 压力测试
我今天在慕课网中无意之间看到压力测试,可以模拟高并发; 顺便看了一下有没有相关的博客,发现下面的这个很详细; //在apache 安装目录下的bin,运行命令 ab -n1000 -c10 http: ...
- MAC 安装 apache ab 压力测试工具以及遇到的坑
ab 是apache对 http服务器进行压力测试的工具,它可以测试出服务器每秒可以处理多少请求.本文记录mac版本安装 ab 的步骤以及遇到的坑. 下载 进入 apache ab官网 下载页面. 安 ...
- 启动Hadoop HDFS时的“Incompatible clusterIDs”错误原因分析
"Incompatible clusterIDs"的错误原因是在执行"hdfs namenode -format"之前,没有清空DataNode节点的data目 ...
- [转载] apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104))
遇见相同的问题. https://www.cnblogs.com/felixzh/p/8295471.html -------------------------------------------- ...
随机推荐
- sp_who_lock
USE MyDataBase GO /****** Object: StoredProcedure [dbo].[sp_who_lock] Script Date: 4/10/2015 ******/ ...
- iOS获取UUID,并使用keychain存储
http://blog.sina.com.cn/s/blog_5971cdd00102vqgy.html
- CocoaPods本身版本的更新
sudo gem update --system sudo gem install cocoapods pod setup pod --version sudo gem install cocoapo ...
- (转载)iOS开发历程书籍推荐
http://www.zhihu.com/question/19649679 我来说说我学习的过程:(无耻的使用一个回答 回答了很多问题.^^) 第一步,精读 Stephen G. Kochan 的& ...
- rake :You have already activated rake 10.1.0
rake aborted! You have already activated rake 10.1.0, but your Gemfile requires rake 10.0.3. Using b ...
- MyBatis入门学习教程-调用存储过程
一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 create table p_user( id int primary key auto_incr ...
- Configure PPPoE on CentOS7
Why? I prefer using ethernet to Wifi to access internet. But, I'm afraid, sometimes I have to use Wi ...
- JVM GC算法 CMS 详解(转)
前言 CMS,全称Concurrent Low Pause Collector,是jdk1.4后期版本开始引入的新gc算法,在jdk5和jdk6中得到了进一步改进,它的主要适合场景是对响应时间的重要性 ...
- HUD 4007 [扫描线][序]
/* 大连热身B题 不要低头,不要放弃,不要气馁,不要慌张 题意: 坐标平面内给很多个点,放置一个边长为r的与坐标轴平行的正方形,问最多有多少个点在正方形内部. 思路: 按照x先排序,然后确定x在合法 ...
- Android性能优化典范
来源:http://hukai.me/android-performance-patterns/#jtss-tsina 0)Render Performance 大多数用户感知到的卡顿等性能问题的最主 ...