菜鸟的性能测试之路(一)——Apache Bench

在公司业务高速增长的大前提下,我重新开始关注专项测试。在和架构师讨论过后,接下来会优先关注性能测试,其中包括两个核心工具:Apache Jmeter和Apache Bench。在此前的工作中,我只用过LR(Loadrunner)工具来进行性能测试,但是这个工具我个人感觉并不轻量,使用起来要花费大量人力物力。相对而言,Jmeter和Bench这两种工具轻量化,更适合中小企业使用。Apache Jmeter在以前的接口测试时候使用过,在现业务里应该也会作为压测工具。但毕竟是对Jmeter有过接触,所以我决定先了解Apache Bench。


初识Apache Bench

Apache Bench 是 Apache 服务器的一个web压力测试工具,简称ab(是的,你没有听错,我当初也以为是Angelababy来着)。ab也是一个命令行工具,对发起负载的本机要求很低,根据ab命令可以创建很多的并发访问线程,模拟多个访问者同时对某一个URL地址进行访问,因此可以用来测试目标服务器的负载压力。总体来说,ab工具小巧简单,上手学习较快,可以提供需要的基本性能指标;但是缺点就是没有图形化结果,不能监控。


安装Apache Bench

要使用ab,首先要下载Apache服务器,从Apache官网首页可以找到下载的页面。但是目前网上大都是针对linux下ab的使用,我这里需要在Windows环境下进行ab的安装与使用。但是Apache官方只提供Apache的源码版,也就是source版,而不提供二进制版(Binaries)。一般来说各个平台下的Binaries版本都是一些社区或其它网站提供的,我们在Windows上使用ab,肯定要用已经编译好的版本。想获取二进制版本,可以在ApacheHaus、Apache Lounge、BitNami WAMP Stack、WampServer、XAMPP选择一个网站来下载,我个人亲测Apache Lounge可用,具体地址如下:Apache Lounge下载地址


Apache Lounge下载页面


进入页面之后,根据自己需要下载32位和64位版本。这里要注意的是,要正常运行Apache 2.4 的话,需要先安装最新版C++ Redistributable Visual Studio 2017组件,也可以在这个页面进行下载。组件安装完成之后,把下载好的Apache解压,会发现里面有个ReadMe的文档,一定要好好看一下,涉及到安装环境和注意事项。


ReadMe文档


从文档中可以看到,Apache需要解压在一个盘符的根目录下,这就是所谓的“ServerRoot”,默认是配置在:{Apache24}\conf\httpd.conf这个文件中的。


httpd.conf


但是从httpd.conf可以看出,默认配置的ServerRoot是放在了C盘(C:/Apache24),所以我把文件解压放到C盘(如果放到D盘还是无法运行的)。这些步骤准备好了之后,就可以运行bin目录下的httpd.exe文件,运行之后后台服务就启动了,这时候在浏览器中输入:http://localhost/,如果能够看到测试页面,就说明服务启动成功了。


localhost页面


使用Apache bench


这时候我要开始使用Apache Bench的功能了,在命令行下跳转到bin目录下,运行ab.exe就能够看到提示信息了:


ab第一次使用


这里可以注意到一个用法说明:Usage: ab.exe [options] [http://]hostname[:port]/path。也就是说,一定要在需要测试的url末尾加一个path,否则测试时会认为url非法。

这里我先尝试一下对百度首页进行一个请求总数为1000,本次请求并发数为500的测试,测试结果如下:


1
2

可以看到,如图列出了“请求命令”、“测试结果主体”、“所测试数据返回时间的百分比”,其中,“测试结果主体”里面,具体的参数为:

Concurrency Level: 并发量。(500)

Time taken for tests: 整个测试所用的时间。(34.809 s)

Complete requests: 完成的请求数。(1000)

Failed requests: 失败的请求数。(0)

Non-2xx responses: 如果接收到的HTTP响应数据的头信息中含有2XX以外的状态码,则会在测试结果中显示另一个名为“Non-2xx responses”的统计项,用于统计这部分请求数(这些请求并不算在失败的请求中)。(1000)

Total transferred: 表示所有请求的响应数据长度总和,包括每个HTTP响应数据的头信息和正文数据的长度。(502000 bytes)

HTML transferred: 表示所有请求的响应数据中正文数据的总和,也就是减去了Total transferred中HTTP响应数据中的头信息的长度。(222000 bytes)

Requests per second(RPS): 吞吐率。要清楚吞吐率是与并发数相关的,即使请求总数相同,但如果并发数不一样,吞吐率还是很可能有很大差异的。 (28.73【#/second】)

计算公式:Complete requests/Time taken for tests

Time per request(mean): 用户平均请求等待时间。也就是一次并发总的时间。 (17404.500 ms)

计算公式:Time token for tests/(Complete requests/Concurrency Level)。

Time per request(mean, across all concurrent requests): 服务器平均请求等待时间。也就是一次请求(在本例中也就是500中的平均每一次)所需时间。 (34.809 ms)

计算公式:Time taken for tests/Complete requests  ; 也可以这么统计:Time per request/Concurrency Level。

Transfer rate: 表示这些请求在单位时间内从服务器获取的数据长度。 (14.08 Kbytes/sec)

计算公式:Total trnasferred/ Time taken for tests 

这个统计很好的说明服务器的处理能力达到极限时,其出口宽带的需求量。

Percentage of requests served within a certain time (ms) : 这部分数据用于描述每个请求处理时间的分布情况,比如以上测试,80%的请求处理时间都不超过6ms,这个处理时间是指前面的Time per request,即对于单个用户而言,平均每个请求的处理时间。


更多命令参数参考:

-n requests Number of requests to perform //本次测试发起的总请求数

-c concurrency Number of multiple requests to make   //一次产生的请求数(或并发数)

-t timelimit Seconds to max. wait for responses    //测试所进行的最大秒数,默认没有时间限制。

-r Don't exit on socket receive errors.    // 抛出异常继续执行测试任务

-p postfile File containing data to POST  //包含了需要POST的数据的文件,文件格式如“p1=1&p2=2”.使用方法是 -p 111.txt

-T content-type Content-type header for POSTing

//POST数据所使用的Content-type头信息,如 -T “application/x-www-form-urlencoded” 。 (配合-p)

-v verbosity How much troubleshooting info to print

//设置显示信息的详细程度 – 4或更大值会显示头信息, 3或更大值可以显示响应代码(404, 200等), 2或更大值可以显示警告和其他信息。 -V 显示版本号并退出。

-C attribute Add cookie, eg. -C “c1=1234,c2=2,c3=3” (repeatable)

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

提示:可以借助session实现原理传递 JSESSIONID参数, 实现保持会话的功能,如-C ” c1=1234,c2=2,c3=3, JSESSIONID=FF056CD16DA9D71CB131C1D56F0319F8″ 。

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



总体体验下来,具有轻量化特点的bench还是很适合中小企业使用,尤其在于模拟访问页面的多机测试。最后,希望更多行业大牛可以多多给我指教和交流,助我一起成长。


读更多的好书,拍更美的照片,写更酷的代码,遇见更有趣的人,愿望是实现从IT菜鸟到全栈工程师的蜕变。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,646评论 18 139
  • 网站性能压力测试是服务器网站性能调优过程中必不可缺少的一环。只有让服务器处在高压情况下,才能真正体现出软件、硬件等...
    mode1943阅读 1,514评论 1 2
  • 很多Node.js初学者都会有这样的疑惑,Node.js到底是单线程的还是多线程的?通过本章的学习,能够让读者较为...
    越努力越幸运_952c阅读 3,642评论 4 36
  • 把我剥开咬一口把我缝起来亲一口 你无需担忧反正你是在做梦
    陈果_周绿阅读 176评论 0 1
  • 如果感觉身上的西服不是很笔挺,首先应该怀疑西服的尺寸不合身。是否觉得宽松,西服尺寸偏大等。上世纪80年代,曾经流行...
    凯绚门阅读 565评论 0 1